/* ========= Soulsound Asia ========= */
:root{
  --ink:#161226;          /* deep plum-ink (from logo's dark center) */
  --ink-2:#1E2A33;        /* ocean-dark */
  --plum:#4C434E;         /* logo indigo-plum */
  --ocean:#1C4B5B;        /* logo ocean teal */
  --rust:#BF7A5A;         /* logo terracotta */
  --amber:#D09C62;        /* logo warm amber */
  --amber-soft:#E6C49A;
  --mist:#F8F5EF;         /* warm off-white ground */
  --mist-2:#F1ECE3;
  --cream:#FBF8F2;
  --ice-2:#EFE9F0;        /* soft plum wash for cards */
  --accent:#C98A5E;       /* terracotta accent */
  --accent-deep:#9C6450;
  --gold:#D09C62;         /* warm gold highlight */
  --slate:#5B5566;        /* muted plum-grey body */
  --line:rgba(76,67,78,.14);
  --shadow:0 18px 50px -20px rgba(22,18,38,.32);
  --r:18px;
  --maxw:1180px;
  --serif:"Cormorant Garamond",Georgia,serif;
  --body:"Outfit","Helvetica Neue",Arial,sans-serif;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  font-family:var(--body);
  color:var(--ink);
  background:var(--mist);
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}

/* ---- type ---- */
h1,h2,h3{font-family:var(--serif);font-weight:600;line-height:1.04;letter-spacing:-.01em}
.eyebrow{
  font-family:var(--body);font-size:.74rem;font-weight:600;letter-spacing:.28em;
  text-transform:uppercase;color:var(--accent-deep);
}
.lead{font-size:1.18rem;color:var(--slate);max-width:60ch}

/* ---- layout ---- */
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 26px}
section{position:relative}
.pad{padding:108px 0}
.pad-sm{padding:72px 0}

/* ---- nav ---- */
header.nav{
  position:sticky;top:0;z-index:50;
  backdrop-filter:saturate(140%) blur(12px);
  background:rgba(244,247,252,.82);
  border-bottom:1px solid var(--line);
}
.nav-in{display:flex;align-items:center;justify-content:space-between;height:74px}
.brand{display:flex;align-items:center;gap:11px;font-family:var(--serif);font-size:1.34rem;font-weight:600;color:var(--ink);letter-spacing:.01em}
.brand .mark{width:58px;height:auto;flex:none}
.brand .wordmark{font-weight:600;text-transform:uppercase;letter-spacing:.12em;font-family:var(--body);font-size:.96rem}
.navlinks{display:flex;gap:30px;align-items:center}
.navlinks a{font-size:.95rem;color:var(--slate);position:relative;padding:6px 0;transition:color .25s}
.navlinks a:hover,.navlinks a.active{color:var(--ink)}
.navlinks a.active::after{content:"";position:absolute;left:0;right:0;bottom:0;height:2px;background:var(--gold);border-radius:2px}
.btn{
  display:inline-flex;align-items:center;gap:9px;
  font-family:var(--body);font-weight:600;font-size:.95rem;
  padding:13px 24px;border-radius:100px;border:1px solid transparent;cursor:pointer;
  transition:transform .25s ease, box-shadow .25s ease, background .25s ease;
}
.btn-primary{background:var(--ocean);color:#fff;box-shadow:0 10px 24px -12px rgba(28,75,91,.42)}
.btn-primary:hover{transform:translateY(-2px);box-shadow:0 16px 30px -12px rgba(30,39,97,.75)}
.btn-ghost{background:transparent;color:var(--ink);border-color:var(--line)}
.btn-ghost:hover{background:#fff;border-color:var(--cream);transform:translateY(-2px)}
.btn-light{background:#fff;color:var(--ocean)}
.btn-light:hover{transform:translateY(-2px);box-shadow:var(--shadow)}
.nav-cta{display:flex;gap:12px;align-items:center}
.burger{display:none;flex-direction:column;gap:5px;background:none;border:0;cursor:pointer;padding:8px}
.burger span{width:24px;height:2px;background:var(--ink);border-radius:2px;transition:.3s}

/* ---- hero ---- */
.hero{
  position:relative;color:#fff;overflow:hidden;
  background:
    radial-gradient(120% 120% at 82% -10%, #C98A5E 0%, rgba(201,138,94,0) 50%),
    radial-gradient(100% 100% at 4% 116%, #1C4B5B 0%, rgba(28,75,91,0) 58%),
    linear-gradient(155deg,#2A2235 0%,#161226 55%,#15303A 100%);
}
.hero .wrap{position:relative;z-index:3;padding-top:120px;padding-bottom:128px}
.hero-logo{width:128px;height:auto;margin-bottom:28px;filter:drop-shadow(0 8px 24px rgba(0,0,0,.3))}
.hero h1{font-size:clamp(2.9rem,6.4vw,5.4rem);color:#fff;max-width:15ch}
.hero .lead{color:var(--cream);margin-top:22px;font-size:1.24rem}
.hero-cta{margin-top:38px;display:flex;gap:14px;flex-wrap:wrap}
.hero-meta{margin-top:54px;display:flex;gap:38px;flex-wrap:wrap;color:var(--cream)}
.hero-meta .stat b{font-family:var(--serif);font-size:2rem;display:block;color:#fff;line-height:1}
.hero-meta .stat span{font-size:.82rem;letter-spacing:.04em;opacity:.8}
/* resonance rings */
.rings{position:absolute;inset:0;z-index:1;pointer-events:none}
.rings i{position:absolute;border-radius:50%;border:1px solid rgba(208,156,98,.26)}
.rings i:nth-child(1){width:340px;height:340px;top:-90px;right:6%}
.rings i:nth-child(2){width:560px;height:560px;top:-200px;right:-3%}
.rings i:nth-child(3){width:800px;height:800px;top:-320px;right:-12%}
.rings .dot{width:14px;height:14px;border-radius:50%;background:var(--amber);border:0;top:78px;right:calc(6% + 163px);box-shadow:0 0 24px 4px rgba(208,156,98,.6)}

/* ---- generic section heading ---- */
.sec-head{max-width:62ch}
.sec-head h2{font-size:clamp(2.1rem,4vw,3.2rem);margin-top:14px}
.sec-head p{margin-top:16px}

/* ---- cards grid ---- */
.grid{display:grid;gap:24px}
.g-2{grid-template-columns:repeat(2,1fr)}
.g-3{grid-template-columns:repeat(3,1fr)}
.g-4{grid-template-columns:repeat(4,1fr)}
.card{
  background:#fff;border:1px solid var(--line);border-radius:var(--r);padding:30px;
  transition:transform .3s ease, box-shadow .3s ease;
}
.card:hover{transform:translateY(-6px);box-shadow:var(--shadow)}
.card .ic{width:52px;height:52px;border-radius:14px;display:grid;place-items:center;background:var(--ice-2);margin-bottom:18px}
.card .ic svg{width:26px;height:26px;stroke:var(--ocean)}
.card h3{font-size:1.5rem;margin-bottom:8px}
.card p{color:var(--slate);font-size:.98rem}

/* feature band */
.band{background:var(--ink);color:#fff;border-radius:28px;padding:60px;position:relative;overflow:hidden}
.band h2{color:#fff;font-size:clamp(2rem,3.6vw,2.9rem)}
.band .lead{color:var(--cream)}

/* steps */
.steps{counter-reset:s;display:grid;gap:22px;grid-template-columns:repeat(4,1fr)}
.step{background:#fff;border:1px solid var(--line);border-radius:var(--r);padding:26px}
.step .n{width:44px;height:44px;border-radius:50%;background:var(--ocean);color:#fff;display:grid;place-items:center;font-family:var(--serif);font-size:1.3rem;margin-bottom:16px}
.step h3{font-size:1.25rem;margin-bottom:6px}
.step p{color:var(--slate);font-size:.93rem}

/* pricing */
.tiers{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;align-items:stretch}
.tier{background:#fff;border:1px solid var(--line);border-radius:var(--r);padding:30px 24px;text-align:center;position:relative;display:flex;flex-direction:column}
.tier.feat{background:var(--ocean);color:#fff;border-color:var(--ocean)}
.tier .name{font-family:var(--body);font-weight:600;letter-spacing:.16em;text-transform:uppercase;font-size:.78rem;color:var(--accent-deep)}
.tier.feat .name{color:var(--cream)}
.tier .size{font-size:.92rem;color:var(--slate);margin-top:6px}
.tier.feat .size{color:var(--cream)}
.tier .price{font-family:var(--serif);font-size:3rem;margin:18px 0 2px;color:var(--ocean)}
.tier.feat .price{color:#fff}
.tier .per{font-size:.82rem;color:var(--slate)}
.tier.feat .per{color:var(--cream)}
.tier .tag{position:absolute;top:-13px;left:50%;transform:translateX(-50%);background:var(--gold);color:#231a06;font-size:.68rem;font-weight:700;letter-spacing:.12em;padding:6px 14px;border-radius:100px}

/* list ticks */
.ticks{list-style:none;display:grid;gap:14px}
.ticks li{display:flex;gap:12px;align-items:flex-start;color:var(--slate)}
.ticks svg{width:22px;height:22px;flex:none;stroke:var(--ocean);margin-top:2px}

/* quote */
.quote{font-family:var(--serif);font-size:clamp(1.5rem,3vw,2.3rem);line-height:1.3;color:var(--ink);max-width:24ch}
.quote .gold{color:var(--gold)}

/* CTA strip */
.cta{background:var(--ink);color:#fff;border-radius:28px;padding:64px;text-align:center;position:relative;overflow:hidden}
.cta h2{color:#fff;font-size:clamp(2rem,4vw,3rem)}
.cta .lead{color:var(--cream);margin:16px auto 30px}

/* footer */
footer{background:var(--ink);color:var(--cream);padding:64px 0 34px}
footer a{color:var(--cream);opacity:.82;transition:opacity .2s}
footer a:hover{opacity:1}
.foot-grid{display:grid;grid-template-columns:1.6fr 1fr 1fr 1fr;gap:30px}
.foot-grid h4{font-family:var(--body);font-size:.78rem;letter-spacing:.18em;text-transform:uppercase;color:var(--accent);margin-bottom:16px}
.foot-grid ul{list-style:none;display:grid;gap:10px;font-size:.95rem}
.foot-bottom{margin-top:46px;padding-top:24px;border-top:1px solid rgba(202,220,252,.16);display:flex;justify-content:space-between;flex-wrap:wrap;gap:10px;font-size:.84rem;opacity:.7}

/* forms */
.field{display:grid;gap:7px;margin-bottom:18px}
.field label{font-size:.86rem;font-weight:600;color:var(--ink)}
.field input,.field select,.field textarea{
  font-family:var(--body);font-size:1rem;padding:14px 16px;border:1px solid var(--line);
  border-radius:12px;background:#fff;color:var(--ink);transition:border .2s,box-shadow .2s;width:100%;
}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 4px rgba(201,138,94,.2)}
.note{font-size:.86rem;color:var(--slate)}

/* reveal animation */
.reveal{opacity:0;transform:translateY(26px);transition:opacity .8s cubic-bezier(.16,1,.3,1),transform .8s cubic-bezier(.16,1,.3,1)}
.reveal.in{opacity:1;transform:none}
.no-js .reveal{opacity:1;transform:none}
@media (prefers-reduced-motion: reduce){.reveal{opacity:1;transform:none;transition:none}}

/* page hero (interior) */
.phero{background:radial-gradient(110% 130% at 90% -20%, rgba(201,138,94,.55) 0%, rgba(201,138,94,0) 55%),linear-gradient(155deg,#2A2235 0%,#161226 60%,#15303A 100%);color:#fff;position:relative;overflow:hidden}
.phero .wrap{position:relative;z-index:3;padding:96px 0 84px}
.phero h1{font-size:clamp(2.4rem,5vw,4rem);color:#fff;max-width:18ch}
.phero .lead{color:var(--cream);margin-top:18px}

.split{display:grid;grid-template-columns:1.1fr .9fr;gap:54px;align-items:center}
.media{border-radius:24px;overflow:hidden;box-shadow:var(--shadow);aspect-ratio:4/5;position:relative}
.media.tall{aspect-ratio:3/4}
.media img{width:100%;height:100%;object-fit:cover}
.badge-soft{display:inline-flex;gap:8px;align-items:center;background:var(--ice-2);color:var(--ocean);padding:8px 16px;border-radius:100px;font-size:.85rem;font-weight:600}

/* responsive */
@media(max-width:980px){
  .g-4{grid-template-columns:repeat(2,1fr)}
  .g-3{grid-template-columns:1fr}
  .tiers{grid-template-columns:repeat(2,1fr)}
  .steps{grid-template-columns:repeat(2,1fr)}
  .foot-grid{grid-template-columns:1fr 1fr}
  .split{grid-template-columns:1fr;gap:32px}
  .band{padding:42px}
}
@media(max-width:680px){
  .pad{padding:72px 0}
  .navlinks,.nav-cta .btn-ghost{display:none}
  .burger{display:flex}
  .g-2,.g-4,.tiers,.steps{grid-template-columns:1fr}
  .foot-grid{grid-template-columns:1fr}
  .cta,.band{padding:36px 24px}
  .mobile-open .navlinks{
    display:flex;position:absolute;top:74px;left:0;right:0;flex-direction:column;
    background:var(--mist);padding:22px 26px;gap:18px;border-bottom:1px solid var(--line);
  }
}
