:root{
  --bg:#fbf7f2;            /* warm cream */
  --bg-2:#ffffff;          /* card surface */
  --fg:#1a1530;            /* deep ink */
  --muted:#6b6781;
  --line:rgba(26,21,48,.10);
  --accent:#ff5fa8;        /* pink */
  --accent-2:#5b6cff;      /* indigo */
  --accent-3:#1fc7a3;      /* mint */
  --accent-4:#ffb648;      /* warm yellow */
  --grad-hero:linear-gradient(120deg,#ff5fa8 0%,#5b6cff 45%,#1fc7a3 100%);
  --grad-bar:linear-gradient(90deg,#ff5fa8,#ffb648,#1fc7a3);
  --radius:14px;
  --maxw:1100px;
  --ease:cubic-bezier(.2,.7,.2,1);
}
*{box-sizing:border-box}
html,body{margin:0;padding:0;color:var(--fg);font-family:-apple-system,BlinkMacSystemFont,"Inter","Segoe UI",sans-serif;line-height:1.55;-webkit-font-smoothing:antialiased}
body{
  background:
    radial-gradient(1100px 650px at 85% -10%, rgba(91,108,255,.20), transparent 60%),
    radial-gradient(950px 550px at -10% 15%, rgba(255,95,168,.18), transparent 60%),
    radial-gradient(950px 700px at 50% 110%, rgba(31,199,163,.16), transparent 60%),
    var(--bg);
  background-attachment: fixed;
}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
::selection{background:var(--accent);color:#fff}

html{scroll-behavior:smooth}

/* Layout */
.container{max-width:var(--maxw);margin:0 auto;padding:0 24px}
main{padding-bottom:80px}

/* Nav */
.nav{position:sticky;top:0;z-index:20;display:flex;align-items:center;justify-content:space-between;
  padding:18px 24px;background:rgba(251,247,242,.75);backdrop-filter:blur(14px);border-bottom:1px solid var(--line)}
.brand{font-weight:600;letter-spacing:-.02em;font-size:18px}
.brand span{color:var(--accent)}
.nav nav a{margin-left:22px;font-size:14px;color:var(--muted);transition:color .25s var(--ease)}
.nav nav a:hover,.nav nav a.active{color:var(--fg)}

/* Hero */
.hero{position:relative;overflow:hidden;padding:120px 24px 140px;text-align:center}
.hero-inner{position:relative;max-width:820px;margin:0 auto;z-index:1}
.kicker{text-transform:uppercase;letter-spacing:.18em;font-size:11px;color:var(--muted);margin:0 0 18px}
h1{font-size:clamp(44px,7vw,84px);line-height:1.02;letter-spacing:-.03em;margin:0 0 22px;font-weight:600}
.grad{background:var(--grad-hero);-webkit-background-clip:text;background-clip:text;color:transparent;background-size:200% 200%;animation:shimmer 8s ease-in-out infinite}
@keyframes shimmer{0%,100%{background-position:0% 50%}50%{background-position:100% 50%}}
.lead{font-size:clamp(16px,1.6vw,18px);color:var(--muted);max-width:560px;margin:0 auto 32px}
.cta-row{display:flex;gap:12px;justify-content:center;flex-wrap:wrap}

/* Buttons */
.btn{display:inline-flex;align-items:center;gap:6px;padding:12px 20px;border-radius:999px;font-size:14px;
  border:1px solid var(--line);transition:transform .25s var(--ease),background .25s var(--ease),color .25s var(--ease);cursor:pointer}
.btn:hover{transform:translateY(-2px)}
.btn.primary{background:var(--grad-hero);background-size:180% 180%;color:#fff;border-color:transparent;font-weight:700;box-shadow:0 10px 28px -10px rgba(255,95,168,.55);transition:transform .25s var(--ease),background-position .5s var(--ease),box-shadow .25s var(--ease)}
.btn.primary:hover{background-position:100% 50%;box-shadow:0 14px 34px -10px rgba(91,108,255,.55)}
.btn.ghost{background:rgba(255,255,255,.6);color:var(--fg);backdrop-filter:blur(8px)}
.btn.ghost:hover{background:#fff}
.btn.block{display:flex;justify-content:center;width:100%;margin-top:16px}

/* Orbs */
.orb{position:absolute;border-radius:50%;filter:blur(90px);opacity:.55;pointer-events:none;animation:float 14s ease-in-out infinite}
.orb-1{width:380px;height:380px;background:var(--accent);top:-90px;left:-70px}
.orb-2{width:440px;height:440px;background:var(--accent-2);bottom:-130px;right:-90px;animation-delay:-7s}
.orb-3{position:absolute;width:300px;height:300px;border-radius:50%;filter:blur(90px);opacity:.45;background:var(--accent-3);top:30%;right:20%;animation:float 16s ease-in-out infinite;animation-delay:-3s;pointer-events:none}
@keyframes float{0%,100%{transform:translateY(0)}50%{transform:translateY(30px)}}

/* Cards grid */
.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin:40px auto}
@media(max-width:760px){.grid-3{grid-template-columns:1fr}}
.card{position:relative;padding:26px;border:1px solid var(--line);border-radius:var(--radius);background:linear-gradient(180deg,var(--bg-2),transparent);transition:transform .35s var(--ease),border-color .35s var(--ease),box-shadow .35s var(--ease);overflow:hidden}
.card::before{content:"";position:absolute;inset:0;border-radius:inherit;padding:1px;background:var(--grad-hero);-webkit-mask:linear-gradient(#000 0 0) content-box,linear-gradient(#000 0 0);-webkit-mask-composite:xor;mask-composite:exclude;opacity:0;transition:opacity .35s var(--ease);pointer-events:none}
.card:hover{transform:translateY(-4px);box-shadow:0 18px 40px -22px rgba(124,140,255,.55)}
.card:hover::before{opacity:.9}
.card:nth-child(3n+1) h3{color:var(--accent)}
.card:nth-child(3n+2) h3{color:var(--accent-2)}
.card:nth-child(3n+3) h3{color:var(--accent-3)}
.card h3{margin:0 0 8px;font-weight:600;letter-spacing:-.01em}
.card p{margin:0;color:var(--muted);font-size:14px}

/* Bands */
.band{padding:80px 24px;text-align:center}
.band h2{font-size:clamp(28px,4vw,42px);letter-spacing:-.02em;margin:0 0 10px;font-weight:600}
.muted{color:var(--muted)}
.small{font-size:12px}

/* Page heads */
.page-head{padding:80px 0 30px;text-align:center;max-width:680px;margin:0 auto}
.page-head h1{font-size:clamp(40px,6vw,68px)}

/* Estimator */
.estimator{margin:60px auto;border:1px solid var(--line);border-radius:20px;padding:36px;background:rgba(255,255,255,.78);backdrop-filter:blur(10px);box-shadow:0 20px 50px -30px rgba(26,21,48,.25)}
.est-head{text-align:center;margin-bottom:28px}
.est-head h2{font-size:clamp(26px,3.5vw,38px);letter-spacing:-.02em;margin:6px 0 6px;font-weight:600}
.est-grid{display:grid;grid-template-columns:1.4fr 1fr;gap:28px}
@media(max-width:760px){.est-grid{grid-template-columns:1fr}}
.field{display:flex;flex-direction:column;gap:8px;margin-bottom:16px;font-size:13px;color:var(--muted)}
.field.full{grid-column:1/-1}
.field input,.field select,.field textarea{
  background:#fff;color:var(--fg);border:1px solid var(--line);border-radius:10px;padding:12px 14px;font:inherit;outline:none;
  transition:border-color .2s var(--ease),box-shadow .2s var(--ease)}
.field input:focus,.field select:focus,.field textarea:focus{border-color:var(--accent-2);box-shadow:0 0 0 3px rgba(124,140,255,.22)}
.field input[type=range]{padding:0;background:transparent;border:none;accent-color:var(--accent)}
.addons{border:1px dashed var(--line);border-radius:12px;padding:16px;margin:0}
.addons legend{padding:0 6px;font-size:12px;color:var(--muted);text-transform:uppercase;letter-spacing:.15em}
.addons label{display:flex;align-items:center;gap:10px;padding:8px 0;font-size:14px;color:var(--fg);cursor:pointer}
.addons em{margin-left:auto;color:var(--muted);font-style:normal;font-size:12px}
.addons input[type=checkbox]{accent-color:var(--accent);width:16px;height:16px}

.est-result{position:sticky;top:90px;align-self:start;border:1px solid var(--line);border-radius:16px;padding:24px;background:#fff;text-align:center;box-shadow:0 14px 36px -22px rgba(26,21,48,.25)}
.price{font-size:64px;letter-spacing:-.04em;font-weight:700;margin:6px 0 14px;display:flex;justify-content:center;align-items:flex-start;gap:2px}
.price .currency{font-size:24px;color:var(--muted);margin-top:14px}
#total{transition:transform .25s var(--ease);display:inline-block;color:black}
.bar{height:6px;background:rgba(26,21,48,.08);border-radius:99px;overflow:hidden;margin:6px 0 12px}
.bar-fill{height:100%;width:0;background:var(--grad-bar);transition:width .4s var(--ease)}
.price{background:var(--grad-hero);-webkit-background-clip:text;background-clip:text;color:transparent}
.price .currency{-webkit-text-fill-color:var(--muted)}

/* Contact */
.contact{display:grid;grid-template-columns:1fr 1fr;gap:18px;max-width:780px;margin:40px auto 80px}
@media(max-width:640px){.contact{grid-template-columns:1fr}}
.contact .full,.contact button,.contact > p{grid-column:1/-1}
.contact button{justify-self:start}

/* Footer */
.foot{display:flex;justify-content:space-between;align-items:center;padding:24px;border-top:1px solid var(--line);color:var(--muted);font-size:13px;flex-wrap:wrap;gap:10px}
.foot a:hover{color:var(--fg)}

/* Reveal anim */
.reveal{opacity:0;transform:translateY(20px);transition:opacity .8s var(--ease),transform .8s var(--ease)}
.reveal.in{opacity:1;transform:none}

/* Hide any stray Lovable badge if injected */
[data-lovable-badge],#lovable-badge,a[href*="lovable.dev"][target="_blank"][class*="badge" i]{display:none!important}

/* About blurb */
.about{max-width:760px;text-align:center;padding:60px 24px 20px}
.kicker.center{text-align:center}
.about-title{font-size:clamp(26px,3.6vw,38px);letter-spacing:-.02em;margin:6px 0 18px;font-weight:600}
.about-text{color:var(--muted);font-size:17px;line-height:1.7}
.about-text strong{color:var(--fg)}
