/* =========================================================
   Phantasia Creative Works — v4
   Roboto · light default + designed dark · calm spacing
   ========================================================= */

:root, [data-theme="light"]{
  --bg:#FFFFFF;
  --bg-2:#F7F8FA;
  --surface:#FFFFFF;
  --alt:#F5F6F8;
  --line:#E6E8EC;
  --line-2:#EEF0F3;
  --ink:#1F2024;
  --ink-2:#5B5E66;
  --muted:#8A8D96;
  --accent:#2563EB;
  --accent-ink:#1D4FD8;
  --accent-soft:#EEF3FE;
  --shadow:0 1px 2px rgba(16,24,40,.04), 0 8px 24px -12px rgba(16,24,40,.12);
  --shadow-lg:0 2px 4px rgba(16,24,40,.05), 0 24px 48px -16px rgba(16,24,40,.18);
}
[data-theme="dark"]{
  --bg:#0E1014;
  --bg-2:#14161B;
  --surface:#171A20;
  --alt:#14161B;
  --line:#262A32;
  --line-2:#20242B;
  --ink:#ECEEF2;
  --ink-2:#AEB2BC;
  --muted:#7C828E;
  --accent:#5B9BFF;
  --accent-ink:#3B7FE8;
  --accent-soft:#17243B;
  --shadow:0 1px 2px rgba(0,0,0,.3), 0 12px 30px -14px rgba(0,0,0,.6);
  --shadow-lg:0 2px 6px rgba(0,0,0,.4), 0 30px 60px -20px rgba(0,0,0,.7);
}

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
@media (prefers-reduced-motion:reduce){html{scroll-behavior:auto}*{animation:none!important;transition:none!important}}

body{
  font-family:"Roboto",system-ui,-apple-system,"Segoe UI",sans-serif;
  background:var(--bg); color:var(--ink);
  font-size:17px; line-height:1.6; letter-spacing:-.002em;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
  transition:background .4s ease, color .4s ease;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
::selection{background:var(--accent);color:#fff}

.wrap{width:100%;max-width:1120px;margin-inline:auto;padding-inline:clamp(22px,5vw,64px)}
.section{padding-block:clamp(80px,11vw,140px)}
.section--tight{padding-block:clamp(64px,8vw,100px)}

/* ---- type ---- */
h1,h2,h3,h4{font-weight:500;letter-spacing:-.022em;line-height:1.15;color:var(--ink)}
.display{font-size:clamp(2.5rem,5.4vw,4.1rem);font-weight:500;letter-spacing:-.035em;line-height:1.05}
h2{font-size:clamp(1.9rem,3.6vw,2.7rem)}
h3{font-size:1.3rem}
.lead{font-size:clamp(1.1rem,1.7vw,1.3rem);color:var(--ink-2);line-height:1.5;font-weight:400}
.eyebrow{font-size:.8rem;font-weight:500;letter-spacing:.08em;text-transform:uppercase;color:var(--accent);margin-bottom:16px}
.muted{color:var(--muted)}

.head{max-width:600px;margin-bottom:clamp(44px,6vw,68px)}
.head .lead{margin-top:14px}
.center{text-align:center;margin-inline:auto}

/* ---- buttons ---- */
.btn{
  display:inline-flex;align-items:center;gap:.5em;
  font-size:.97rem;font-weight:500;
  padding:.8em 1.5em;border-radius:100px;border:1px solid transparent;
  cursor:pointer;transition:all .25s ease;white-space:nowrap;
}
.btn--primary{background:var(--accent);color:#fff!important}
.btn--primary:hover{background:var(--accent-ink);color:#fff!important;transform:translateY(-1px);box-shadow:var(--shadow)}
.btn--primary:active{transform:translateY(0);filter:brightness(.94)}
.btn--primary:disabled,.btn--primary[aria-disabled="true"]{background:var(--line);color:var(--muted)!important;cursor:not-allowed;transform:none;box-shadow:none}
.btn--ghost{background:var(--surface);color:var(--ink);border-color:var(--line)}
.btn--ghost:hover{border-color:var(--ink-2);background:var(--alt)}
.btn--text{color:var(--accent);padding-inline:.4em}
.btn--text:hover{gap:.7em}
.btn:focus-visible{outline:2px solid var(--accent);outline-offset:2px}

/* ---- nav ---- */
.nav{
  position:fixed;inset:0 0 auto 0;z-index:100;
  display:flex;align-items:center;justify-content:space-between;
  padding:14px clamp(22px,5vw,64px);
  transition:background .3s ease,border-color .3s ease,padding .3s ease;
  border-bottom:1px solid transparent;
}
.nav.scrolled{background:color-mix(in srgb,var(--bg) 82%,transparent);backdrop-filter:blur(16px) saturate(180%);-webkit-backdrop-filter:blur(16px) saturate(180%);border-bottom-color:var(--line)}
.nav__brand{display:flex;align-items:center;gap:10px}
.nav__brand img{height:28px;width:auto}
.nav__right{display:flex;align-items:center;gap:8px}
.nav__links{display:flex;align-items:center;gap:2px}
.nav__links a{font-size:.92rem;font-weight:500;color:var(--ink-2);padding:8px 14px;border-radius:8px;transition:.2s}
.nav__links a:hover{color:var(--ink);background:var(--alt)}
.nav__cta{margin-left:6px}

/* theme toggle */
.toggle{
  width:38px;height:38px;border-radius:10px;border:1px solid var(--line);
  background:var(--surface);color:var(--ink-2);
  display:grid;place-items:center;cursor:pointer;transition:.2s;
}
.toggle:hover{color:var(--ink);border-color:var(--ink-2)}
.toggle svg{width:18px;height:18px}
.toggle .sun{display:none}
[data-theme="dark"] .toggle .sun{display:block}
[data-theme="dark"] .toggle .moon{display:none}

.nav__toggle{display:none;background:none;border:0;padding:9px;flex-direction:column;gap:5px;cursor:pointer}
.nav__toggle span{display:block;width:22px;height:2px;background:var(--ink);border-radius:2px;transition:.3s}
@media(max-width:880px){
  .nav__links{
    position:fixed;inset:0 0 0 auto;width:min(290px,80vw);
    flex-direction:column;align-items:flex-start;justify-content:center;gap:4px;padding:36px;
    background:var(--surface);border-left:1px solid var(--line);
    transform:translateX(100%);transition:transform .35s ease;
  }
  .nav__links.open{transform:none}
  .nav__links a{font-size:1.1rem;padding:12px 0;width:100%}
  .nav__cta{margin:12px 0 0}
  .nav__toggle{display:flex;z-index:110}
  .nav__toggle.open span:first-child{transform:translateY(7px) rotate(45deg)}
  .nav__toggle.open span:nth-child(2){opacity:0}
  .nav__toggle.open span:last-child{transform:translateY(-7px) rotate(-45deg)}
}

/* ---- hero ---- */
.hero{padding-top:clamp(130px,16vh,180px);padding-bottom:clamp(60px,8vw,90px)}
.hero__grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(32px,5vw,64px);align-items:center}
.hero__title{margin-bottom:0}
.hero__sub{font-size:clamp(1.1rem,1.7vw,1.28rem);color:var(--ink-2);margin-top:22px;max-width:40ch;line-height:1.5}
.hero__actions{display:flex;flex-wrap:wrap;gap:12px;margin-top:34px}
.hero__visual{position:relative;border-radius:20px;overflow:hidden;aspect-ratio:1/1.05;background:var(--alt);border:1px solid var(--line);box-shadow:var(--shadow)}
.hero__visual img{width:100%;height:100%;object-fit:cover}
.hero__badge{position:absolute;left:16px;bottom:16px;background:color-mix(in srgb,var(--surface) 80%,transparent);backdrop-filter:blur(10px);border:1px solid var(--line);padding:6px 12px;border-radius:100px;font-size:.78rem;font-weight:400;color:var(--ink-2);display:flex;align-items:center;gap:7px}
.hero__badge .dot{width:7px;height:7px;border-radius:50%;background:#16A34A;opacity:.9}
[data-theme="dark"] .hero__badge .dot{background:#22C55E}
@media(max-width:860px){
  .hero__grid{grid-template-columns:1fr;gap:36px}
  .hero__visual{order:-1;aspect-ratio:4/3;max-height:42vh}
  .hero__sub{max-width:none}
}

/* ---- trust strip ---- */
.strip{border-block:1px solid var(--line);background:var(--bg-2)}
.strip__inner{display:flex;flex-wrap:wrap;gap:clamp(24px,5vw,72px);justify-content:center;padding-block:26px;align-items:center}
.strip__item{display:flex;flex-direction:column;align-items:center;text-align:center;gap:2px}
.strip__item b{font-size:1.05rem;font-weight:600}
.strip__item span{font-size:.84rem;color:var(--muted)}

/* ---- services ---- */
.svc-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.svc{
  background:var(--surface);border:1px solid var(--line);border-radius:18px;
  padding:30px 28px 32px;transition:transform .3s ease,box-shadow .3s ease,border-color .3s ease;
}
.svc:hover{transform:translateY(-4px);box-shadow:var(--shadow);border-color:var(--line)}
.svc__ic{width:46px;height:46px;border-radius:12px;background:var(--accent-soft);display:grid;place-items:center;margin-bottom:20px}
.svc__ic svg{width:24px;height:24px;stroke:var(--accent)}
.svc h3{margin-bottom:8px}
.svc p{color:var(--ink-2);font-size:.96rem}
@media(max-width:820px){.svc-grid{grid-template-columns:1fr}}

/* ---- portfolio ---- */
.tabs{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:28px}
.tab{
  font-size:.9rem;font-weight:500;color:var(--ink-2);
  padding:8px 18px;border-radius:100px;border:1px solid var(--line);background:var(--surface);
  cursor:pointer;transition:.2s;
}
.tab:hover{border-color:var(--ink-2);color:var(--ink)}
.tab.active{background:var(--ink);color:var(--bg);border-color:var(--ink)}
.pgrid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.pcard{
  position:relative;border-radius:16px;overflow:hidden;aspect-ratio:4/5;
  background:var(--alt);border:1px solid var(--line);cursor:pointer;
  transition:box-shadow .35s ease,transform .35s ease;
}
.pcard img{width:100%;height:100%;object-fit:cover;transition:transform .5s ease}
.pcard:hover{box-shadow:var(--shadow-lg);transform:translateY(-3px)}
.pcard:hover img{transform:scale(1.04)}
.pcard.hide{display:none}
@media(max-width:760px){.pgrid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:460px){.pgrid{grid-template-columns:1fr}}

/* ---- process ---- */
.steps{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.step{padding:4px}
.step__n{font-size:.85rem;font-weight:600;color:var(--accent);margin-bottom:12px;display:flex;align-items:center;gap:10px}
.step__n::after{content:"";flex:1;height:1px;background:var(--line)}
.step h4{font-size:1.1rem;margin-bottom:6px}
.step p{font-size:.94rem;color:var(--ink-2)}
@media(max-width:820px){.steps{grid-template-columns:1fr}}

/* ---- pricing ---- */
.price-list{display:flex;flex-direction:column}
.price-row{
  display:grid;grid-template-columns:1.4fr 1fr auto;gap:20px;align-items:center;
  padding:24px 20px;margin-inline:-20px;border-radius:12px;
  position:relative;transition:background .2s ease;
}
.price-row::before{content:"";position:absolute;left:20px;right:20px;top:0;height:1px;background:var(--line)}
.price-row:first-child::before{display:none}
.price-row:hover{background:var(--alt)}
.price-row:hover::before,.price-row:hover+.price-row::before{opacity:0}
.price-row h4{font-size:1.15rem;margin-bottom:3px}
.price-row p{font-size:.92rem;color:var(--muted)}
.price-row .amt{font-size:1.3rem;font-weight:600;letter-spacing:-.02em}
.price-row .amt span{font-size:.9rem;color:var(--muted);font-weight:400}
@media(max-width:680px){
  .price-row{grid-template-columns:1fr;gap:8px;padding:22px 4px}
  .price-row .btn{justify-self:start;margin-top:6px}
}
.price-note{text-align:center;color:var(--muted);font-size:.9rem;margin-top:28px}

/* ---- availability ---- */
.avail{display:grid;grid-template-columns:.85fr 1.15fr;gap:clamp(32px,5vw,60px);align-items:center}
.avail__status{display:inline-flex;align-items:center;gap:9px;font-size:.92rem;font-weight:500;color:#0E7A45;background:#E7F6EE;padding:8px 16px;border-radius:100px;margin-bottom:18px}
[data-theme="dark"] .avail__status{color:#4ADE80;background:#10231A}
.avail__status .dot{width:8px;height:8px;border-radius:50%;background:currentColor}
.slots{border:1px solid var(--line);border-radius:16px;overflow:hidden;background:var(--surface)}
.slot{display:grid;grid-template-columns:42px 1fr 120px;gap:14px;align-items:center;padding:15px 20px;border-top:1px solid var(--line-2);font-size:.93rem}
.slot:first-child{border-top:0}
.slot__n{color:var(--muted);font-variant-numeric:tabular-nums}
.slot__bar{display:flex;align-items:center;gap:10px;color:var(--ink-2);font-size:.85rem;font-variant-numeric:tabular-nums}
.bar{flex:1;height:5px;border-radius:100px;background:var(--line);overflow:hidden}
.bar>i{display:block;height:100%;background:var(--accent);border-radius:100px}
.slot--open .slot__n,.slot--open>span:nth-child(2){color:var(--accent);font-weight:500}
.slot--open .slot__bar{color:var(--muted)}

/* ---- FAQ accordion ---- */
.faq{max-width:760px;margin-inline:auto}
.qa{border-bottom:1px solid var(--line)}
.qa__q{width:100%;text-align:left;background:none;border:0;cursor:pointer;padding:22px 0;display:flex;justify-content:space-between;align-items:center;gap:20px;font-size:1.05rem;font-weight:500;color:var(--ink);font-family:inherit}
.qa__q:hover{color:var(--accent)}
.qa__ic{flex:none;width:22px;height:22px;position:relative;transition:transform .3s ease}
.qa__ic::before,.qa__ic::after{content:"";position:absolute;background:var(--accent);border-radius:2px;top:50%;left:50%;transform:translate(-50%,-50%)}
.qa__ic::before{width:14px;height:2px}
.qa__ic::after{width:2px;height:14px;transition:transform .3s ease}
.qa.open .qa__ic::after{transform:translate(-50%,-50%) scaleY(0)}
.qa__a{max-height:0;overflow:hidden;transition:max-height .35s ease}
.qa__a p{padding:0 0 22px;color:var(--ink-2);font-size:.97rem;max-width:64ch}

/* ---- CTA band ---- */
.cta{text-align:center}
.cta h2{font-size:clamp(2rem,4.5vw,3rem);max-width:16ch;margin-inline:auto}
.cta .lead{margin:18px auto 0;max-width:46ch}
.cta__actions{display:flex;gap:12px;justify-content:center;flex-wrap:wrap;margin-top:34px}

/* ---- footer ---- */
.footer{background:var(--bg-2);border-top:1px solid var(--line);padding-block:64px 36px}
.footer__top{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:40px;margin-bottom:48px}
.footer__brand img{height:30px;margin-bottom:16px}
.footer__brand p{color:var(--ink-2);font-size:.92rem;max-width:30ch}
.footer__social{display:flex;gap:10px;margin-top:18px}
.footer__social a{width:38px;height:38px;border-radius:10px;border:1px solid var(--line);display:grid;place-items:center;color:var(--ink-2);transition:.2s}
.footer__social a:hover{color:var(--ink);border-color:var(--ink-2);transform:translateY(-2px)}
.footer__social svg{width:18px;height:18px}
.footer__col h5{font-size:.82rem;font-weight:600;letter-spacing:.06em;text-transform:uppercase;color:var(--muted);margin-bottom:16px}
.footer__col a{display:block;color:var(--ink-2);font-size:.93rem;padding:6px 0;transition:.2s}
.footer__col a:hover{color:var(--accent)}
.footer__bottom{display:flex;justify-content:space-between;align-items:center;gap:16px;flex-wrap:wrap;padding-top:28px;border-top:1px solid var(--line);font-size:.86rem;color:var(--muted)}
@media(max-width:820px){.footer__top{grid-template-columns:1fr 1fr;gap:32px}.footer__brand{grid-column:1/-1}}
@media(max-width:480px){.footer__top{grid-template-columns:1fr}}

/* ---- reveal ---- */
[data-reveal]{opacity:0;transform:translateY(18px);transition:opacity .6s ease,transform .6s ease}
[data-reveal].in{opacity:1;transform:none}
[data-reveal][data-delay="1"]{transition-delay:.07s}
[data-reveal][data-delay="2"]{transition-delay:.14s}
[data-reveal][data-delay="3"]{transition-delay:.21s}
