/* Base styles */
:root{
  --bg:#0a0a0f;
  --ink:#f8f9fa;
  --muted:#a8a8b3;
  --brand:#ff6b9d;
  --brand-2:#ff8fab;
  --brand-3:#ffb3c6;
  --brand-ink:#2d1b2e;
  --paper:#1a1a24;
  --accent:#6aebc4;
  --accent-2:#ffd166;
  --accent-3:#8ea0ff;
  --ring: 0 0 0 3px rgba(255,107,157,.4);
  --gradient-1: linear-gradient(135deg, #ff6b9d, #ff8fab, #ffb3c6);
  --gradient-2: linear-gradient(135deg, #6aebc4, #8ea0ff, #ffd166);
  --gradient-3: linear-gradient(135deg, #1a1a24, #2d1b2e, #1a1a24);
}
*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{
  font:16px/1.6 system-ui,-apple-system,Segoe UI,Roboto,Inter,Arial,sans-serif;
  color:var(--ink);
  background:var(--bg);
}
a{color:var(--brand);text-decoration:none}
a:hover{text-decoration:underline}
html{scroll-behavior:smooth}
section{scroll-margin-top:80px}
a{color:var(--brand);text-decoration:none}
a:hover{text-decoration:underline}
img{max-width:100%;height:auto;display:block}
.container{max-width:1000px;margin:0 auto;padding:1.25rem}
.grid-2{display:grid;grid-template-columns:1fr;gap:1rem}
@media(min-width:760px){.grid-2{grid-template-columns:1fr 1fr}}

/* Header */
.site-header{
  position:sticky;
  top:0;
  z-index:10;
  backdrop-filter:saturate(140%) blur(12px);
  background:var(--gradient-3);
  border-bottom:1px solid rgba(255,107,157,.2);
  display:flex;
  align-items:center;
  justify-content:space-between;
  box-shadow:0 4px 20px rgba(0,0,0,.3);
}
.brand{
  display:inline-block;
  padding:1.5rem 2rem;
  font-size:1.8rem;
  font-weight:900;
  letter-spacing:.5px;
  background:var(--gradient-1);
  -webkit-background-clip:text;
  background-clip:text;
  color:transparent;
  text-shadow:0 0 30px rgba(255,107,157,.3);
  position:relative;
}
.brand::after{
  content:'';
  position:absolute;
  bottom:0.5rem;
  left:50%;
  transform:translateX(-50%);
  width:60%;
  height:3px;
  background:var(--gradient-1);
  border-radius:2px;
  opacity:0.7;
}
.menu-toggle{
  margin-right:1.5rem;
  padding:.6rem 1rem;
  border:1px solid rgba(255,107,157,.3);
  border-radius:.8rem;
  background:rgba(255,107,157,.1);
  color:var(--ink);
  font-weight:600;
  transition:all 0.3s ease;
}
.menu-toggle:hover{
  background:rgba(255,107,157,.2);
  transform:translateY(-1px);
}
.site-nav{
  display:flex;
  flex-wrap:wrap;
  gap:.5rem .8rem;
  align-items:center;
  padding:.8rem 2rem 1.2rem;
}
.site-nav a{
  padding:.6rem 1rem;
  border-radius:.8rem;
  color:var(--ink);
  font-weight:500;
  transition:all 0.3s ease;
  position:relative;
}
.site-nav a:hover{
  background:rgba(255,107,157,.1);
  transform:translateY(-1px);
  text-decoration:none;
}
.site-nav a[aria-current="page"]{
  background:var(--gradient-1);
  color:var(--brand-ink);
  font-weight:700;
  box-shadow:0 4px 15px rgba(255,107,157,.3);
}
.site-nav .cta{
  background:var(--gradient-1);
  color:var(--brand-ink);
  font-weight:700;
  box-shadow:0 4px 15px rgba(255,107,157,.3);
}
.site-nav .cta:hover{
  text-decoration:none;
  filter:brightness(1.1);
  transform:translateY(-2px);
  box-shadow:0 6px 20px rgba(255,107,157,.4);
}
@media(max-width:860px){
  .site-nav{display:none}
  body.nav-open .site-nav{
    display:flex;
    flex-direction:column;
    position:absolute;
    top:80px;
    left:0;
    right:0;
    background:var(--gradient-3);
    border-bottom:1px solid rgba(255,107,157,.2);
    padding:2rem;
    box-shadow:0 10px 30px rgba(0,0,0,.3);
    backdrop-filter:blur(12px);
  }
  .brand{
    font-size:1.5rem;
    padding:1rem 1.5rem;
  }
  .hero h1{
    font-size:clamp(2.5rem,8vw,4rem);
  }
}

/* Hero */
.hero{
  position:relative;
  display:block;
  overflow:hidden;
  padding:6rem 0 8rem;
  background:var(--gradient-3);
  min-height:70vh;
  display:flex;
  align-items:center;
}
.hero::before{
  content:"";
  position:absolute;
  inset:-30% -30% 0 -30%;
  background:conic-gradient(
    from 180deg at 50% 50%, 
    rgba(255,107,157,.3), 
    rgba(255,139,171,.2), 
    rgba(106,235,196,.2), 
    rgba(142,160,255,.2), 
    rgba(255,107,157,.3)
  );
  filter:blur(100px) saturate(150%);
  opacity:.6;
  pointer-events:none;
  animation:rotate 20s linear infinite;
}
.hero::after{
  content:"";
  position:absolute;
  top:0;
  left:0;
  right:0;
  bottom:0;
  background:radial-gradient(ellipse at center, rgba(255,107,157,.1) 0%, transparent 70%);
  pointer-events:none;
}
.hero-text{
  position:relative;
  z-index:2;
  padding:2rem 1.25rem;
  text-align:center;
  max-width:800px;
  margin:0 auto;
}
@media(min-width:860px){
  .hero-text{padding:4rem 2rem}
}
.hero h1{
  font-size:clamp(3rem,6vw,5rem);
  margin:0 0 1.5rem;
  background:var(--gradient-1);
  -webkit-background-clip:text;
  background-clip:text;
  color:transparent;
  font-weight:900;
  letter-spacing:-0.02em;
  line-height:1.1;
  text-shadow:0 0 40px rgba(255,107,157,.4);
  position:relative;
}
.hero h1::after{
  content:"Cakesontherise";
  position:absolute;
  top:0;
  left:0;
  right:0;
  background:var(--gradient-2);
  -webkit-background-clip:text;
  background-clip:text;
  color:transparent;
  opacity:0.3;
  z-index:-1;
  transform:translate(2px, 2px);
}
.hero p{
  max-width:60ch;
  font-size:1.2rem;
  line-height:1.7;
  color:var(--muted);
  margin:0 auto 2rem;
}
@keyframes rotate{
  from{transform:rotate(0deg)}
  to{transform:rotate(360deg)}
}

/* Buttons */
.button{
  display:inline-block;
  padding:.8rem 1.5rem;
  border-radius:1rem;
  border:1px solid rgba(255,107,157,.3);
  background:rgba(255,107,157,.1);
  color:var(--ink);
  backdrop-filter:saturate(140%) blur(8px);
  font-weight:600;
  text-decoration:none;
  transition:all 0.3s ease;
  position:relative;
  overflow:hidden;
}
.button::before{
  content:'';
  position:absolute;
  top:0;
  left:-100%;
  width:100%;
  height:100%;
  background:linear-gradient(90deg, transparent, rgba(255,255,255,.1), transparent);
  transition:left 0.5s ease;
}
.button:hover{
  text-decoration:none;
  transform:translateY(-2px);
  box-shadow:0 8px 25px rgba(255,107,157,.3);
  border-color:rgba(255,107,157,.5);
}
.button:hover::before{
  left:100%;
}
.button.primary{
  background:var(--gradient-1);
  color:var(--brand-ink);
  border-color:transparent;
  box-shadow:0 4px 15px rgba(255,107,157,.3);
}
.button.primary:hover{
  filter:brightness(1.1);
  transform:translateY(-3px);
  box-shadow:0 12px 30px rgba(255,107,157,.4);
}

/* Sections */
.intro h2,.highlights h2{
  margin-top:1rem;
  font-size:2.5rem;
  background:var(--gradient-1);
  -webkit-background-clip:text;
  background-clip:text;
  color:transparent;
  text-align:center;
  margin-bottom:2rem;
}
.section{
  padding:4rem 0;
  position:relative;
}
.section::before{
  content:'';
  position:absolute;
  top:0;
  left:50%;
  transform:translateX(-50%);
  width:100px;
  height:3px;
  background:var(--gradient-1);
  border-radius:2px;
}
.signature{
  font-style:italic;
  color:var(--muted);
  font-size:1.1rem;
  text-align:right;
  margin-top:1.5rem;
}
.features{
  display:grid;
  grid-template-columns:1fr;
  gap:2rem;
  padding:0;
  list-style:none;
  margin-top:3rem;
}
@media(min-width:760px){
  .features{grid-template-columns:repeat(3,1fr)}
}
.features h3{
  margin:.4rem 0 1rem;
  font-size:1.3rem;
  color:var(--ink);
}
.features li{
  background:var(--paper);
  border:1px solid rgba(255,107,157,.2);
  border-radius:1.5rem;
  padding:2rem;
  box-shadow:0 10px 40px rgba(0,0,0,.3);
  transition:all 0.3s ease;
  position:relative;
  overflow:hidden;
}
.features li::before{
  content:'';
  position:absolute;
  top:0;
  left:0;
  right:0;
  height:4px;
  background:var(--gradient-1);
}
.features li:hover{
  transform:translateY(-5px);
  box-shadow:0 20px 50px rgba(0,0,0,.4);
}
.features li:nth-child(1){
  border-left:4px solid rgba(106,235,196,.6);
}
.features li:nth-child(2){
  border-left:4px solid rgba(255,107,157,.6);
}
.features li:nth-child(3){
  border-left:4px solid rgba(142,160,255,.6);
}

/* Pricing */
.price-list{list-style:none;padding-left:0}
.price-list li{padding:.25rem 0;border-bottom:1px dashed #e6e6ee}
.note{background:var(--paper);padding:1rem;border-radius:1rem;border:1px solid rgba(255,255,255,.12)}

/* Flavours */
.flavour{margin:1.25rem 0}
.flavour h2{margin-bottom:.2rem}
.servings{columns:2;gap:2rem}
.cards{
  display:grid;
  grid-template-columns:1fr;
  gap:1.5rem;
  margin-top:2rem;
}
@media(min-width:860px){
  .cards{grid-template-columns:repeat(3,1fr)}
}
.card{
  background:var(--paper);
  border:1px solid rgba(255,107,157,.2);
  border-radius:1.5rem;
  padding:2rem;
  transition:all 0.3s ease;
  position:relative;
  overflow:hidden;
}
.card::before{
  content:'';
  position:absolute;
  top:0;
  left:0;
  right:0;
  height:3px;
  background:var(--gradient-1);
}
.card:hover{
  transform:translateY(-3px);
  box-shadow:0 15px 35px rgba(0,0,0,.3);
  border-color:rgba(255,107,157,.4);
}
.card h3{
  color:var(--ink);
  font-size:1.2rem;
  margin-bottom:1rem;
  background:var(--gradient-1);
  -webkit-background-clip:text;
  background-clip:text;
  color:transparent;
}

/* Forms */
.contact-form{
  background:var(--paper);
  padding:2rem;
  border-radius:1.5rem;
  border:1px solid rgba(255,107,157,.2);
  box-shadow:0 10px 40px rgba(0,0,0,.3);
  margin-top:2rem;
}
.contact-form label{
  display:block;
  margin:1rem 0 0.5rem;
  font-weight:600;
  color:var(--ink);
}
.contact-form input,.contact-form textarea{
  width:100%;
  padding:1rem;
  border-radius:1rem;
  border:1px solid rgba(255,107,157,.3);
  background:rgba(255,107,157,.05);
  color:var(--ink);
  font-size:1rem;
  transition:all 0.3s ease;
}
.contact-form input::placeholder,.contact-form textarea::placeholder{
  color:var(--muted);
}
.contact-form input:focus,.contact-form textarea:focus{
  outline:none;
  box-shadow:var(--ring);
  border-color:rgba(255,107,157,.6);
  background:rgba(255,107,157,.1);
}
.actions{
  margin-top:2rem;
  display:flex;
  gap:1rem;
  flex-wrap:wrap;
}
.human-check{
  margin-top:1rem;
  padding:1rem;
  background:rgba(255,107,157,.05);
  border-radius:1rem;
  border:1px solid rgba(255,107,157,.2);
}
.human-row{
  display:flex;
  gap:1rem;
  align-items:center;
}
.human-row span{
  display:inline-block;
  background:var(--gradient-1);
  color:var(--brand-ink);
  padding:.5rem 1rem;
  border-radius:.8rem;
  font-weight:800;
  font-size:1.1rem;
}
.hp{position:absolute;left:-9999px;opacity:0}

/* Footer */
.site-footer{
  border-top:1px solid rgba(255,107,157,.2);
  margin-top:4rem;
  background:var(--gradient-3);
  padding:3rem 0 1rem;
  position:relative;
}
.site-footer::before{
  content:'';
  position:absolute;
  top:0;
  left:0;
  right:0;
  height:3px;
  background:var(--gradient-1);
}
.site-footer .right{
  align-self:end;
  justify-self:end;
}
.legal{
  color:var(--muted);
  text-align:center;
  margin:0;
  padding:2rem 1rem 1rem;
  border-top:1px solid rgba(255,107,157,.1);
  margin-top:2rem;
}

/* Breadcrumbs */
.breadcrumbs{color:var(--muted);font-size:.95rem;margin:.25rem 0 1rem}
.breadcrumbs a{color:inherit}
