/* ============================================================
   Taylormade Creative — Bold Pop
   Social media + Print. Colorful, fun, high-end.
   ============================================================ */

:root{
  /* surface */
  --paper:#FAF7F2;          /* warm off-white */
  --paper-2:#F1EBDF;        /* raised warm */
  --ink:#121318;            /* near-black, never #000 */
  --ink-soft:#4A4C56;       /* muted text */
  --line:rgba(18,19,24,.12);
  --frame:#FBF9F5;          /* warm near-white for photo frames, never pure #fff */

  /* pop */
  --blue:#2E5BFF;  --blue-deep:#1E42D6;
  --pink:#FF4FA3;  --pink-deep:#E23A8B;
  --yellow:#FFD23F; --yellow-deep:#EFBC1C;

  /* type */
  --display:"Bricolage Grotesque",system-ui,sans-serif;
  --body:"Space Grotesk",system-ui,sans-serif;
  --serif:"Fraunces",Georgia,serif;

  --ease:cubic-bezier(.23,1,.32,1);
  --wrap:1240px;
}

*,*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth;scroll-padding-top:90px}
@media (prefers-reduced-motion:reduce){html{scroll-behavior:auto}}
body{
  margin:0;background:var(--paper);color:var(--ink);
  font-family:var(--body);font-size:17px;line-height:1.6;
  -webkit-font-smoothing:antialiased;overflow-x:hidden;
}
img{display:block;max-width:100%;height:auto}
a{color:inherit;text-decoration:none}
::selection{background:var(--yellow);color:var(--ink)}
:focus-visible{outline:3px solid var(--blue);outline-offset:3px;border-radius:4px}
.hero :focus-visible,.cta :focus-visible,.portal :focus-visible,.cd-inner :focus-visible,.svc-blue :focus-visible{outline-color:var(--yellow)}

.wrap{width:min(100% - 2.4rem,var(--wrap));margin-inline:auto}

/* ---------- type ---------- */
.h-display{
  font-family:var(--display);font-weight:800;
  font-size:clamp(2.7rem,7.2vw,6.2rem);line-height:.98;
  letter-spacing:-.025em;margin:0;
}
.h1{
  font-family:var(--display);font-weight:800;
  font-size:clamp(2rem,4.4vw,3.5rem);line-height:1.02;
  letter-spacing:-.02em;margin:0;
}
.serif-em{font-family:var(--serif);font-style:italic;font-weight:500;letter-spacing:0}
.lead{font-size:clamp(1.05rem,1.5vw,1.22rem);color:var(--ink-soft);max-width:54ch;line-height:1.55}
.eyebrow{
  display:inline-flex;align-items:center;gap:.5rem;
  font-weight:600;font-size:.78rem;letter-spacing:.16em;text-transform:uppercase;
  color:var(--ink-soft);
}
.eyebrow.on-color{color:rgba(255,255,255,.95)}
.eyebrow::before{content:"";width:26px;height:2px;background:currentColor;opacity:.5}

/* highlighted accent words */
.hl{position:relative;white-space:nowrap}
.hl::after{content:"";position:absolute;left:-.04em;right:-.04em;bottom:.06em;height:.16em;border-radius:2px;z-index:-1}
.hl-yellow{color:var(--yellow)}.hl-yellow::after{background:rgba(255,210,63,.28)}

/* ---------- buttons ---------- */
.btn{
  display:inline-flex;align-items:center;gap:.5rem;
  font-family:var(--body);font-weight:600;font-size:1rem;
  padding:.85rem 1.4rem;border-radius:999px;border:2px solid transparent;
  cursor:pointer;transition:transform .16s var(--ease),box-shadow .2s var(--ease),background .2s var(--ease);
  will-change:transform;
}
.btn .arr{transition:transform .2s var(--ease)}
.btn:hover .arr{transform:translateX(4px)}
.btn:active{transform:scale(.97)}
.btn-blue{background:var(--blue);color:#fff;box-shadow:0 10px 24px -12px rgba(46,91,255,.7)}
.btn-blue:hover{background:var(--blue-deep);transform:translateY(-2px)}
.btn-yellow{background:var(--yellow);color:var(--ink);box-shadow:0 10px 24px -12px rgba(239,188,28,.8)}
.btn-yellow:hover{background:var(--yellow-deep);transform:translateY(-2px)}
.btn-ghost{background:transparent;color:var(--ink);border-color:rgba(18,19,24,.22)}
.btn-ghost:hover{border-color:var(--ink);transform:translateY(-2px)}
.hero .btn,.cta .btn,.cd-inner .btn,.portal .btn,.plan.featured .btn,.plan.custom .btn{box-shadow:0 14px 30px -16px rgba(0,0,0,.55)}
.btn-ghost-light{background:transparent;color:#fff;border-color:rgba(255,255,255,.34)}
.btn-ghost-light:hover{border-color:#fff;transform:translateY(-2px)}

/* ============================================================
   NAV
   ============================================================ */
.nav{
  position:fixed;inset:0 0 auto 0;z-index:50;
  display:flex;align-items:center;justify-content:space-between;gap:1rem;
  padding:1rem max(1.2rem,calc((100% - var(--wrap))/2));
  transition:background .3s var(--ease),box-shadow .3s var(--ease);
}
.nav.scrolled{background:rgba(250,247,242,.82);backdrop-filter:blur(14px);box-shadow:0 1px 0 var(--line);padding-block:.7rem}
.brand{display:flex;align-items:center;gap:.6rem}
.mark{display:flex;gap:4px}
.mark i{width:10px;height:10px;border-radius:50%}
.mark i:nth-child(1){background:var(--blue)}
.mark i:nth-child(2){background:var(--pink)}
.mark i:nth-child(3){background:var(--yellow)}
.brand-tx{font-family:var(--display);font-weight:800;font-size:1.05rem;line-height:1;letter-spacing:-.02em;display:flex;flex-direction:column;gap:2px}
.brand-tx small{font-family:var(--body);font-weight:500;font-size:.62rem;letter-spacing:.12em;text-transform:uppercase;color:var(--ink-soft)}
.nav-links{display:flex;gap:1.6rem}
.ulink{position:relative;font-weight:500;font-size:.95rem;padding:.2rem 0}
.ulink::after{content:"";position:absolute;left:0;right:0;bottom:-2px;height:2px;background:var(--ink);transform:scaleX(0);transform-origin:left;transition:transform .3s var(--ease)}
.ulink:hover::after{transform:scaleX(1)}
.nav-cta{display:flex;align-items:center;gap:1rem}
.nav-login{display:inline-flex;align-items:center;gap:.45rem;font-weight:500;font-size:.92rem}
.nav-login svg{width:17px;height:17px}
.nav-login:hover{color:var(--blue)}
.nav .btn{padding:.6rem 1.1rem;font-size:.92rem}
.nav-toggle{display:none;flex-direction:column;gap:5px;background:none;border:0;cursor:pointer;padding:11px 9px}
.nav-toggle span{width:26px;height:2.5px;background:var(--ink);border-radius:2px;transition:transform .3s var(--ease),opacity .2s}
.nav-toggle[aria-expanded="true"] span:nth-child(1){transform:translateY(7.5px) rotate(45deg)}
.nav-toggle[aria-expanded="true"] span:nth-child(2){opacity:0}
.nav-toggle[aria-expanded="true"] span:nth-child(3){transform:translateY(-7.5px) rotate(-45deg)}

.mobile-sheet{
  position:fixed;inset:0;z-index:45;background:var(--paper);
  display:flex;flex-direction:column;justify-content:center;gap:.4rem;
  padding:2rem clamp(1.4rem,6vw,3rem);
  transform:translateY(-100%);visibility:hidden;transition:transform .42s var(--ease),visibility 0s .42s;
}
.mobile-sheet.open{transform:translateY(0);visibility:visible;transition-delay:0s}
.mobile-sheet a{font-family:var(--display);font-weight:700;font-size:clamp(1.8rem,8vw,2.6rem);letter-spacing:-.02em;padding:.4rem 0;border-bottom:1px solid var(--line)}
.mobile-sheet .ms-cta{color:var(--blue);border-bottom:0}

/* ============================================================
   NAV over dark hero
   ============================================================ */
.nav .brand-tx{color:#fff}
.nav .brand-tx small{color:rgba(255,255,255,.6)}
.nav .ulink{color:#fff}
.nav .ulink::after{background:#fff}
.nav .nav-login{color:#fff}
.nav .nav-toggle span{background:#fff}
.nav.scrolled .brand-tx,.nav.menu-open .brand-tx{color:var(--ink)}
.nav.scrolled .brand-tx small,.nav.menu-open .brand-tx small{color:var(--ink-soft)}
.nav.scrolled .ulink,.nav.menu-open .ulink{color:var(--ink)}
.nav.scrolled .ulink::after,.nav.menu-open .ulink::after{background:var(--ink)}
.nav.scrolled .nav-login,.nav.menu-open .nav-login{color:var(--ink)}
.nav.scrolled .nav-login:hover,.nav.menu-open .nav-login:hover{color:var(--blue)}
.nav.scrolled .nav-toggle span,.nav.menu-open .nav-toggle span{background:var(--ink)}

/* ============================================================
   HERO (dark)
   ============================================================ */
.hero{position:relative;min-height:100dvh;display:flex;align-items:center;padding:8rem 0 4rem;overflow:hidden;background:var(--ink);color:#fff}
.glow{position:absolute;border-radius:50%;filter:blur(78px);z-index:0;opacity:.42;pointer-events:none}
.glow-blue{width:40vw;height:40vw;max-width:560px;max-height:560px;background:var(--blue);top:-12%;right:4%}
.glow-pink{width:30vw;height:30vw;max-width:400px;max-height:400px;background:var(--pink);bottom:-18%;left:-14%;opacity:.22}
.hero-grid{position:relative;z-index:1;width:min(100% - 2.4rem,var(--wrap));margin-inline:auto;display:grid;grid-template-columns:1.02fr 1.1fr;gap:3rem;align-items:center}
.badge{display:inline-block;font-weight:700;font-size:.72rem;letter-spacing:.14em;text-transform:uppercase;color:#fff;background:var(--blue);padding:.45rem .85rem;border-radius:999px;margin-bottom:1.4rem}
.hero .h-display{margin-bottom:1.4rem}
.hero .h-display .serif-line{display:block;font-family:var(--serif);font-style:italic;font-weight:500;font-size:.6em;letter-spacing:0;margin-top:.12em;color:#fff}
.hero .lead{color:rgba(255,255,255,.78)}
.hero-actions{display:flex;flex-wrap:wrap;gap:.8rem;margin-top:1.9rem}
.scarcity{display:inline-flex;align-items:center;gap:.55rem;margin-top:1.7rem;font-size:.95rem;color:var(--ink-soft);font-weight:500}
.scarcity.center{justify-content:center}
.pulse{width:9px;height:9px;border-radius:50%;background:var(--pink);box-shadow:0 0 0 0 rgba(255,79,163,.55);animation:pulse 2s infinite}
@keyframes pulse{0%{box-shadow:0 0 0 0 rgba(255,79,163,.5)}70%{box-shadow:0 0 0 11px rgba(255,79,163,0)}100%{box-shadow:0 0 0 0 rgba(255,79,163,0)}}
.trust-row{display:flex;align-items:center;gap:.8rem;margin-top:2rem;flex-wrap:wrap}
.avatars{display:flex;align-items:center}
.avatars img{width:40px;height:40px;border-radius:9px;object-fit:cover;border:2px solid var(--frame);margin-left:-9px;box-shadow:0 6px 14px -6px rgba(0,0,0,.6)}
.avatars img:first-child{margin-left:0}
.avatars img:nth-child(odd){transform:rotate(-5deg)}
.avatars img:nth-child(even){transform:rotate(4deg)}
.trust-row span{font-size:.86rem;color:rgba(255,255,255,.78);max-width:26ch}

/* dashboard mockup */
.hero-visual{position:relative;z-index:1}
.dash{background:#1b1c24;border:1px solid rgba(255,255,255,.1);border-radius:18px;padding:1.1rem;box-shadow:0 40px 90px -40px rgba(0,0,0,.85)}
.dash-head{display:flex;align-items:center;gap:.7rem;margin-bottom:1rem}
.dash-logo{display:flex;gap:3px}
.dash-logo i{width:8px;height:8px;border-radius:50%}
.dash-logo i:nth-child(1){background:var(--blue)}.dash-logo i:nth-child(2){background:var(--pink)}.dash-logo i:nth-child(3){background:var(--yellow)}
.dash-welcome b{display:block;font-family:var(--display);font-weight:700;font-size:.98rem}
.dash-welcome small{font-size:.74rem;color:rgba(255,255,255,.5)}
.dash-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:.5rem;margin-bottom:1rem}
.ds{background:rgba(255,255,255,.05);border-radius:11px;padding:.7rem .6rem}
.ds b{font-family:var(--display);font-weight:800;font-size:1.3rem;display:block;line-height:1}
.ds span{font-size:.64rem;color:rgba(255,255,255,.55);display:block;margin-top:.25rem}
.dash-sub{font-size:.68rem;letter-spacing:.1em;text-transform:uppercase;color:rgba(255,255,255,.55);margin-bottom:.5rem}
.dash-thumbs{display:grid;grid-template-columns:repeat(4,1fr);gap:.5rem;margin-bottom:1rem}
.dash-thumbs img{width:100%;aspect-ratio:4/5;object-fit:cover;border-radius:9px}
.dash-order{display:flex;align-items:center;gap:.6rem;background:rgba(255,255,255,.05);border-radius:11px;padding:.6rem .7rem}
.do-ic{width:30px;height:30px;border-radius:8px;background:linear-gradient(135deg,var(--blue),#7e9bff);flex:0 0 auto}
.do-tx{flex:1;min-width:0}
.do-tx b{display:block;font-size:.82rem}
.do-tx small{font-size:.68rem;color:rgba(255,255,255,.5)}
.do-bar{width:60px;height:6px;border-radius:99px;background:rgba(255,255,255,.14);overflow:hidden;flex:0 0 auto}
.do-bar i{display:block;height:100%;background:var(--yellow)}
.do-pct{font-size:.72rem;font-weight:700;color:var(--yellow)}
/* phone */
.phone{position:absolute;right:-6px;bottom:-30px;width:130px;background:#15161d;border:5px solid #2a2b34;border-radius:24px;padding:.7rem .6rem;box-shadow:0 30px 60px -28px rgba(0,0,0,.85)}
.ph-top{font-family:var(--display);font-weight:700;font-size:.86rem;margin-bottom:.55rem}
.ph-top small{display:block;font-family:var(--body);font-weight:500;font-size:.6rem;color:rgba(255,255,255,.45)}
.ph-list{display:flex;flex-direction:column;gap:.45rem}
.ph-row{display:flex;align-items:center;gap:.45rem}
.ph-th{width:30px;height:30px;border-radius:7px;flex:0 0 auto}
.ph-th.th1{background:linear-gradient(135deg,var(--blue),#7e9bff)}
.ph-th.th2{background:linear-gradient(135deg,var(--pink),#ffa0cb)}
.ph-th.th3{background:linear-gradient(135deg,var(--yellow),#ffe79a)}
.ph-mt b{display:block;font-size:.72rem}
.ph-mt small{font-size:.6rem;color:rgba(255,255,255,.45)}

.scroll-cue{position:absolute;left:50%;bottom:1.2rem;transform:translateX(-50%);z-index:1;display:flex;align-items:center;gap:.5rem;font-size:.74rem;letter-spacing:.18em;text-transform:uppercase;color:rgba(255,255,255,.5)}
.scroll-cue .dot{width:7px;height:7px;border-radius:50%;background:var(--yellow);animation:bob 1.6s var(--ease) infinite}
@keyframes bob{0%,100%{transform:translateY(0)}50%{transform:translateY(5px)}}

/* ============================================================
   MARQUEE
   ============================================================ */
.proof{background:var(--ink);color:var(--paper);overflow:hidden;padding:1.3rem 0}
.marquee{display:flex;gap:2.4rem;width:max-content;animation:scroll 34s linear infinite;font-family:var(--display);font-weight:700;font-size:1.3rem;letter-spacing:-.01em}
.marquee .sep{color:var(--yellow)}
@keyframes scroll{to{transform:translateX(-50%)}}
@media (prefers-reduced-motion:reduce){.marquee{animation:none}}

/* ============================================================
   SECTIONS
   ============================================================ */
.section{padding:clamp(4.5rem,9vw,8rem) 0}
.intro{padding-block:clamp(4rem,8vw,7rem) clamp(2.5rem,5vw,4rem)}
.intro-grid{display:grid;grid-template-columns:1.25fr .75fr;gap:clamp(2rem,5vw,4rem);align-items:center}
.intro-art{margin:0;border-radius:16px;overflow:hidden;border:6px solid var(--frame);box-shadow:0 30px 60px -30px rgba(18,19,24,.45);transform:rotate(3deg);max-width:340px;justify-self:end}
.intro-art img{display:block;width:100%}
.big-statement{font-family:var(--display);font-weight:700;font-size:clamp(1.5rem,3.4vw,2.5rem);line-height:1.24;letter-spacing:-.02em;max-width:24ch;margin:0}
.big-statement .serif-em{color:var(--blue)}

/* ---------- what we do ---------- */
.whatwedo .wwd-row{display:flex;flex-wrap:wrap;gap:.9rem;margin-bottom:.9rem}
.whatwedo .wwd-row.offset{padding-left:clamp(0rem,6vw,5rem);margin-bottom:0}
.wwd{display:grid;grid-template-columns:auto 1fr;grid-template-rows:auto auto;column-gap:.65rem;align-items:center;background:#fff;border:1px solid var(--line);border-radius:16px;padding:.9rem 1.15rem;box-shadow:0 14px 30px -22px rgba(18,19,24,.35);transition:transform .25s var(--ease),box-shadow .25s var(--ease)}
.wwd:hover{transform:translateY(-3px);box-shadow:0 22px 40px -24px rgba(18,19,24,.45)}
.wwd i{grid-row:1/3;width:13px;height:13px;border-radius:50%}
.wwd b{font-family:var(--display);font-weight:700;font-size:1rem;line-height:1.1}
.wwd span{font-size:.84rem;color:var(--ink-soft)}
.d-blue{background:var(--blue)}.d-pink{background:var(--pink)}.d-yellow{background:var(--yellow)}
.sec-head{display:grid;grid-template-columns:1.1fr .9fr;gap:2rem;align-items:end;margin-bottom:3rem}
.sec-head .eyebrow{margin-bottom:1rem}

/* ---------- service blocks ---------- */
.svc-block{position:relative;overflow:hidden;padding:clamp(4rem,8vw,7rem) 0}
.svc-blue{background:var(--blue);color:#fff}
.svc-pink{background:var(--pink);color:var(--ink)}
.svc-inner{display:grid;grid-template-columns:1fr 1fr;gap:clamp(2rem,5vw,4.5rem);align-items:center}
.svc-inner.reverse .svc-copy{order:2}
.svc-copy .eyebrow{margin-bottom:1.1rem}
.svc-copy .h1{margin-bottom:1.2rem}
.svc-lead{font-size:clamp(1.02rem,1.4vw,1.16rem);line-height:1.55;max-width:46ch;margin:0 0 1.6rem}
.svc-blue .svc-lead{color:rgba(255,255,255,.9)}
.svc-pink .svc-lead{color:rgba(18,19,24,.82)}
.ticks{list-style:none;margin:0 0 1.6rem;padding:0;display:grid;gap:.6rem}
.ticks li{position:relative;padding-left:2rem;font-weight:500}
.ticks li::before{content:"";position:absolute;left:0;top:.16em;width:1.25rem;height:1.25rem;border-radius:50%;background:rgba(255,255,255,.18);background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23fff' stroke-width='3'%3E%3Cpath d='M20 6 9 17l-5-5'/%3E%3C/svg%3E");background-size:64%;background-repeat:no-repeat;background-position:center}
.ticks.pink li::before{background:var(--ink);background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23FF4FA3' stroke-width='3'%3E%3Cpath d='M20 6 9 17l-5-5'/%3E%3C/svg%3E")}
.svc-proof{font-size:.98rem;color:rgba(255,255,255,.9)}
.svc-proof b{color:#fff;font-weight:700}
.flow{display:inline-flex;align-items:center;gap:.7rem;font-family:var(--display);font-weight:700;font-size:1.05rem;background:var(--ink);color:#fff;padding:.6rem 1.1rem;border-radius:999px}
.flow i{color:var(--yellow);font-style:normal}

/* service art */
.svc-art{position:relative;min-height:380px}
.float-img{margin:0;position:absolute;border-radius:14px;overflow:hidden;border:6px solid var(--frame);box-shadow:0 30px 60px -30px rgba(0,0,0,.5);width:54%}
.float-img img{aspect-ratio:4/5;object-fit:cover;width:100%}
.fi-a{top:0;left:2%;transform:rotate(-5deg);z-index:3}
.fi-b{top:14%;right:0;transform:rotate(4deg);z-index:2;width:50%}
.fi-c{bottom:0;left:18%;transform:rotate(2deg);z-index:1;width:50%}
.print-stack{position:relative;min-height:360px;display:flex;align-items:center;justify-content:center}
.ps-img{width:78%;max-width:420px;border-radius:16px;border:6px solid var(--frame);box-shadow:0 34px 64px -32px rgba(0,0,0,.55);transform:rotate(-2deg)}
.chip{position:absolute;background:var(--frame);color:var(--ink);font-family:var(--display);font-weight:700;font-size:1.02rem;padding:.65rem 1.15rem;border-radius:999px;box-shadow:0 18px 40px -22px rgba(0,0,0,.5);display:inline-flex;align-items:center;gap:.5rem;z-index:2}
.chip::before{content:"";width:10px;height:10px;border-radius:50%}
.chip-1{top:6%;left:2%;transform:rotate(-7deg)}.chip-1::before{background:var(--blue)}
.chip-2{top:44%;right:0;transform:rotate(5deg)}.chip-2::before{background:var(--yellow)}
.chip-3{bottom:8%;left:10%;transform:rotate(4deg)}.chip-3::before{background:var(--blue)}

/* inline service links */
.svc-link{display:inline-flex;align-items:center;gap:.45rem;margin-top:1.3rem;font-weight:700;color:#fff;border-bottom:2px solid rgba(255,255,255,.5);padding-bottom:.15rem;transition:border-color .2s var(--ease)}
.svc-link:hover{border-color:#fff}
.svc-link .arr{transition:transform .2s var(--ease)}
.svc-link:hover .arr{transform:translateX(4px)}
.svc-link.on-ink{color:var(--ink);border-color:rgba(18,19,24,.4)}
.svc-link.on-ink:hover{border-color:var(--ink)}

/* ============================================================
   WORK
   ============================================================ */
.work-filters{display:flex;flex-wrap:wrap;gap:.6rem;margin-bottom:1.8rem}
.work-filters button{font-family:var(--body);font-weight:600;font-size:.92rem;padding:.5rem 1.1rem;border-radius:999px;border:2px solid var(--line);background:transparent;color:var(--ink);cursor:pointer;transition:transform .16s var(--ease),background .2s,border-color .2s,color .2s}
.work-filters button:hover{border-color:var(--ink)}
.work-filters button:active{transform:scale(.96)}
.work-filters button.active{background:var(--ink);color:#fff;border-color:var(--ink)}
.work-grid{columns:3;column-gap:1.1rem}
.work-item{break-inside:avoid;margin:0 0 1.1rem;position:relative;border-radius:16px;overflow:hidden;cursor:pointer;background:var(--paper-2);transition:transform .3s var(--ease),box-shadow .3s var(--ease)}
.work-item img{width:100%;transition:transform .5s var(--ease)}
.work-item:hover{transform:translateY(-4px);box-shadow:0 26px 50px -28px rgba(18,19,24,.5)}
.work-item:hover img{transform:scale(1.04)}
.work-item.hide{display:none}
.work-cap{position:absolute;inset:auto 0 0 0;display:flex;justify-content:space-between;align-items:flex-end;gap:.5rem;padding:1.4rem .9rem .8rem;color:#fff;background:linear-gradient(to top,rgba(10,11,15,.78),transparent);opacity:0;transform:translateY(6px);transition:opacity .3s var(--ease),transform .3s var(--ease)}
.work-item:hover .work-cap{opacity:1;transform:translateY(0)}
.c-type{font-size:.74rem;letter-spacing:.06em;text-transform:uppercase;opacity:.85}
.c-client{font-family:var(--display);font-weight:700}

/* ============================================================
   PRINT PRODUCTS
   ============================================================ */
.pc-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:1rem;margin-bottom:2rem}
.pcard{position:relative;border-radius:18px;overflow:hidden;aspect-ratio:1/1;color:#fff;background:var(--paper-2);transition:transform .3s var(--ease),box-shadow .3s var(--ease)}
.pcard:hover{transform:translateY(-5px);box-shadow:0 26px 50px -28px rgba(18,19,24,.5)}
.pc-img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;transition:transform .5s var(--ease)}
.pcard:hover .pc-img{transform:scale(1.05)}
.pcard::after{content:"";position:absolute;inset:0;background:linear-gradient(to top,rgba(10,11,15,.72),rgba(10,11,15,.08) 48%,rgba(10,11,15,0) 70%)}
.pc-tag{position:absolute;top:.75rem;left:.75rem;z-index:2;font-size:.7rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--ink);background:var(--yellow);padding:.28rem .6rem;border-radius:999px}
.pc-body{position:absolute;left:0;right:0;bottom:0;z-index:2;padding:1rem 1.05rem}
.pcard h3{font-family:var(--display);font-weight:700;font-size:1.1rem;margin:0;line-height:1.05}
.pc-price{display:block;margin-top:.2rem;font-size:.92rem;font-weight:600}
.pc-price small{font-weight:500;opacity:.82;font-size:.8rem}
.pc-more{background:linear-gradient(135deg,var(--pink),var(--pink-deep))}
.pc-more::after{display:none}
.pc-more .pc-body{top:50%;bottom:auto;transform:translateY(-50%);text-align:center}
.pc-more span{display:block;margin-top:.35rem;font-size:.82rem;color:rgba(255,255,255,.85)}
.pc-features{display:flex;flex-wrap:wrap;justify-content:center;align-items:center;gap:.7rem;color:var(--ink-soft);font-weight:600;font-size:.95rem;margin-bottom:1.6rem}
.pc-features i{color:var(--pink)}
.pc-cta{text-align:center}

/* ============================================================
   PORTAL
   ============================================================ */
.portal{display:grid;grid-template-columns:1fr 1fr;gap:clamp(2rem,5vw,4.5rem);align-items:center;background:var(--ink);color:var(--paper);border-radius:28px;padding:clamp(2rem,5vw,4rem)}
.portal .eyebrow{color:rgba(255,255,255,.6);margin-bottom:1rem}
.portal .h1{margin-bottom:1.1rem}
.portal .lead{color:rgba(255,255,255,.78)}
.portal .ticks li::before{background:rgba(255,255,255,.16)}
.portal-actions{margin-top:1.6rem}
.portal-window{background:#1c1d24;border:1px solid rgba(255,255,255,.1);border-radius:16px;overflow:hidden;box-shadow:0 40px 80px -40px rgba(0,0,0,.7)}
.pw-bar{display:flex;align-items:center;gap:.45rem;padding:.8rem 1rem;border-bottom:1px solid rgba(255,255,255,.08)}
.pw-bar i{width:11px;height:11px;border-radius:50%}
.pw-bar i:nth-child(1){background:var(--pink)}.pw-bar i:nth-child(2){background:var(--yellow)}.pw-bar i:nth-child(3){background:var(--blue)}
.pw-title{margin-left:.6rem;font-size:.8rem;color:rgba(255,255,255,.5)}
.pw-body{padding:.9rem}
.pw-row{display:flex;align-items:center;gap:.8rem;padding:.7rem;border-radius:11px;background:rgba(255,255,255,.04);margin-bottom:.6rem}
.pw-row:last-child{margin-bottom:0}
.pw-thumb{width:42px;height:42px;border-radius:9px;flex:0 0 auto}
.pw-thumb.t1{background:linear-gradient(135deg,var(--blue),#7a96ff)}
.pw-thumb.t2{background:linear-gradient(135deg,var(--pink),#ff9ac9)}
.pw-thumb.t3{background:linear-gradient(135deg,var(--yellow),#ffe79a)}
.pw-thumb.t4{background:linear-gradient(135deg,var(--blue),#7e9bff)}
.pw-lines{flex:1;display:flex;flex-direction:column;gap:.4rem}
.pw-lines b{height:8px;border-radius:4px;background:rgba(255,255,255,.16);display:block}
.pw-lines b.short{width:55%}
.pw-pill{font-size:.7rem;font-weight:700;padding:.28rem .6rem;border-radius:999px;white-space:nowrap}
.pw-pill.ok{background:rgba(255,210,63,.92);color:var(--ink)}
.pw-pill.rev{background:rgba(255,210,63,.18);color:var(--yellow)}
.pw-pill.sch{background:rgba(46,91,255,.2);color:#88a3ff}

/* ============================================================
   CONTENT DAY
   ============================================================ */
.contentday{padding:0 clamp(.6rem,2vw,1.4rem);margin-top:clamp(4.5rem,9vw,8rem)}
.cd-inner{background:var(--ink);color:#fff;border-radius:32px;padding:clamp(2rem,5vw,3.5rem);display:grid;grid-template-columns:.85fr 1.15fr;gap:clamp(2rem,5vw,4rem);align-items:center}
.cd-visual{position:relative;min-height:260px}
.cd-free{position:absolute;z-index:4;top:-4px;left:40%;background:var(--pink);color:#fff;font-family:var(--display);font-weight:800;font-size:1rem;padding:.3rem .8rem;border-radius:999px;transform:rotate(-8deg)}
.cd-p{margin:0;position:absolute;width:48%;border-radius:12px;overflow:hidden;border:5px solid var(--frame);box-shadow:0 24px 50px -26px rgba(0,0,0,.7)}
.cd-p img{width:100%;aspect-ratio:4/5;object-fit:cover}
.cd-p1{top:4%;left:4%;transform:rotate(-7deg);z-index:3}
.cd-p2{top:16%;left:32%;transform:rotate(6deg);z-index:2}
.cd-p3{top:40%;left:16%;transform:rotate(-2deg);z-index:1}
.cd-copy .eyebrow{margin-bottom:1rem}
.cd-copy .h1{margin-bottom:1rem}
.cd-copy p{color:rgba(255,255,255,.78);max-width:48ch;margin:0 0 1.6rem}
.cd-actions{display:flex;flex-wrap:wrap;align-items:center;gap:1rem}
.cd-note{display:inline-flex;align-items:center;gap:.5rem;font-size:.9rem;color:rgba(255,255,255,.7)}

/* ============================================================
   PACKAGES
   ============================================================ */
.packages .sec-head.center{grid-template-columns:1fr;text-align:center;justify-items:center;margin-bottom:3rem}
.packages .sec-head.center .lead{margin-inline:auto}
.plan-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1.1rem;align-items:start}
.plan{background:var(--paper-2);border-radius:20px;padding:1.7rem 1.4rem;display:flex;flex-direction:column;gap:.45rem;height:100%}
.plan-name{font-family:var(--display);font-weight:700;font-size:1.15rem}
.plan-price{font-family:var(--display);font-weight:800;font-size:2.4rem;line-height:1;letter-spacing:-.02em}
.plan-price span{font-family:var(--body);font-weight:600;font-size:.92rem;color:var(--ink-soft);letter-spacing:0}
.plan-note{font-size:.72rem;font-weight:700;color:var(--ink-soft);text-transform:uppercase;letter-spacing:.08em;margin-bottom:.3rem}
.plan-feats{list-style:none;margin:.4rem 0 1.3rem;padding:0;display:grid;gap:.55rem;flex:1}
.plan-feats li{position:relative;padding-left:1.7rem;font-size:.93rem}
.plan-feats li.plus{padding-left:0;font-weight:700;font-size:.86rem;letter-spacing:.04em;margin-bottom:.1rem}
.plan-feats li.plus::before{display:none}
.plan-feats li::before{content:"";position:absolute;left:0;top:.12em;width:1.1rem;height:1.1rem;border-radius:50%;background:var(--blue);background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23fff' stroke-width='3.2'%3E%3Cpath d='M20 6 9 17l-5-5'/%3E%3C/svg%3E");background-size:62%;background-repeat:no-repeat;background-position:center}
.plan .btn{justify-content:center;width:100%}
.plan.featured{background:var(--ink);color:#fff;position:relative;box-shadow:0 34px 64px -34px rgba(18,19,24,.65)}
.plan.featured .plan-price span{color:rgba(255,255,255,.6)}
.plan.featured .plan-note{color:rgba(255,255,255,.55)}
.plan-flag{position:absolute;top:-12px;left:50%;transform:translateX(-50%);background:var(--yellow);color:var(--ink);font-weight:700;font-size:.68rem;letter-spacing:.08em;text-transform:uppercase;padding:.32rem .8rem;border-radius:999px;white-space:nowrap}
.plan-feats.light li::before{background:var(--yellow);background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23121318' stroke-width='3.2'%3E%3Cpath d='M20 6 9 17l-5-5'/%3E%3C/svg%3E")}
.plan.custom{background:var(--blue);color:#fff;justify-content:center;text-align:center;gap:.9rem}
.plan.custom .plan-name{font-size:1.25rem}
.plan.custom p{color:rgba(255,255,255,.88);font-size:.95rem;margin:0}

/* FAQ */
.faq{display:grid;grid-template-columns:1fr 1fr;gap:1rem;margin-top:2.6rem}
.faq details{background:var(--paper-2);border-radius:16px;padding:1.1rem 1.3rem}
.faq summary{font-family:var(--display);font-weight:700;font-size:1.05rem;cursor:pointer;list-style:none;display:flex;justify-content:space-between;align-items:center;gap:1rem}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:"+";font-weight:700;font-size:1.3rem;color:var(--blue);transition:transform .25s var(--ease)}
.faq details[open] summary::after{transform:rotate(45deg)}
.faq details p{margin:.7rem 0 0;color:var(--ink-soft);font-size:.97rem;max-width:60ch}

/* sticky mobile CTA */
.sticky-cta{position:fixed;left:0;right:0;bottom:0;z-index:40;display:none;padding:.7rem 1rem calc(.7rem + env(safe-area-inset-bottom));background:rgba(250,247,242,.92);backdrop-filter:blur(12px);box-shadow:0 -1px 0 var(--line);transform:translateY(110%);transition:transform .35s var(--ease)}
.sticky-cta.show{transform:translateY(0)}
.sticky-cta .btn{width:100%;justify-content:center}

/* ============================================================
   WORDS
   ============================================================ */
.words{padding-top:0}
.trust{display:flex;flex-wrap:wrap;align-items:center;gap:.8rem;justify-content:center;margin-bottom:3rem;color:var(--ink-soft)}
.trust span{font-size:.78rem;letter-spacing:.16em;text-transform:uppercase}
.trust b{font-family:var(--display);font-weight:700;font-size:1.25rem;color:var(--ink)}
.trust i{color:var(--pink);font-style:normal}
.quotes{display:grid;grid-template-columns:1.3fr 1fr;gap:1.2rem}
.quote{margin:0;background:var(--paper-2);border-radius:20px;padding:2rem;position:relative}
.quote.feature{background:var(--blue);color:#fff}
.quote p{font-family:var(--display);font-weight:700;font-size:clamp(1.2rem,2vw,1.6rem);line-height:1.25;letter-spacing:-.01em;margin:0 0 1.4rem}
.quote.feature p::before{content:"“";font-size:2rem;color:var(--yellow);line-height:0;vertical-align:-.3em;margin-right:.1em}
.who{display:flex;flex-direction:column}
.who b{font-weight:700}
.who span{font-size:.9rem;color:var(--ink-soft)}
.quote.feature .who span{color:rgba(255,255,255,.75)}

/* ============================================================
   BOOK (embedded scheduler)
   ============================================================ */
.book{padding-top:0}
.book .sec-head.center{grid-template-columns:1fr;text-align:center;justify-items:center;margin-bottom:2.2rem}
.book .sec-head.center .lead{margin-inline:auto}
.book-frame{position:relative;border-radius:24px;overflow:hidden;background:var(--paper-2);border:1px solid var(--line);box-shadow:0 40px 80px -44px rgba(18,19,24,.5);height:min(72dvh,680px)}
.book-frame::before{content:"Loading your calendar…";position:absolute;inset:0;display:flex;align-items:center;justify-content:center;font-family:var(--display);font-weight:700;font-size:1.1rem;color:var(--ink-soft)}
.book-frame iframe{position:relative;display:block;width:100%;height:100%;border:0;background:transparent}
.book-alt{text-align:center;margin-top:1.1rem;font-size:.92rem;color:var(--ink-soft)}
.book-alt a{font-weight:600;color:var(--blue)}
.book-alt a:hover{text-decoration:underline}

/* ============================================================
   CTA
   ============================================================ */
.cta{position:relative;background:var(--ink);background-image:radial-gradient(620px 620px at 88% -12%,rgba(46,91,255,.38),transparent 64%),radial-gradient(480px 480px at -6% 112%,rgba(255,79,163,.26),transparent 64%);color:var(--paper);text-align:center;overflow:hidden;margin:0 clamp(.6rem,2vw,1.4rem) clamp(.6rem,2vw,1.4rem);border-radius:32px}
.cta .wrap{position:relative;z-index:1;display:flex;flex-direction:column;align-items:center}
.cta-h{margin:1.2rem 0 1.4rem}
.cta .lead{color:rgba(255,255,255,.8);margin-inline:auto;text-align:center}
.cta-actions{display:flex;flex-wrap:wrap;gap:.8rem;justify-content:center;margin-top:1.8rem}
.cta .scarcity{color:rgba(255,255,255,.82)}

/* ============================================================
   FOOTER
   ============================================================ */
.footer{padding:3rem 0}
.footer-grid{display:flex;flex-wrap:wrap;justify-content:space-between;align-items:center;gap:1.4rem;padding-bottom:1.6rem;border-bottom:1px solid var(--line)}
.footer-nav{display:flex;flex-wrap:wrap;gap:1.4rem}
.footer-legal{display:flex;flex-wrap:wrap;justify-content:space-between;gap:.6rem;padding-top:1.4rem;font-size:.86rem;color:var(--ink-soft)}

/* ============================================================
   LIGHTBOX
   ============================================================ */
.lightbox{position:fixed;inset:0;z-index:80;background:rgba(12,12,16,.92);display:none;align-items:center;justify-content:center;padding:5vw}
.lightbox.open{display:flex;animation:fade .25s var(--ease)}
@keyframes fade{from{opacity:0}to{opacity:1}}
.lightbox img{max-width:92vw;max-height:88vh;border-radius:12px;box-shadow:0 30px 80px -20px rgba(0,0,0,.7)}
.lb-close{position:absolute;top:1.2rem;right:1.4rem;width:46px;height:46px;border-radius:50%;border:0;background:rgba(255,255,255,.12);color:#fff;font-size:1.2rem;cursor:pointer;transition:transform .16s var(--ease),background .2s}
.lb-close:hover{background:rgba(255,255,255,.24)}
.lb-close:active{transform:scale(.94)}

/* ============================================================
   REVEAL
   ============================================================ */
html.js [data-reveal]{opacity:0;transform:translateY(16px);transition:opacity .55s var(--ease),transform .55s var(--ease)}
html.js [data-reveal].in{opacity:1;transform:none}
[data-reveal][data-d="1"]{transition-delay:.08s}
[data-reveal][data-d="2"]{transition-delay:.16s}
[data-reveal][data-d="3"]{transition-delay:.24s}
@media (prefers-reduced-motion:reduce){
  [data-reveal]{opacity:1;transform:none;transition:none}
  .pulse,.scroll-cue .dot,.glow{animation:none}
}

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (hover:none){
  .work-cap{opacity:1;transform:none}
}
@media (max-width:1000px){
  .work-grid{columns:2}
  .pc-grid{grid-template-columns:repeat(3,1fr)}
  .plan-grid{grid-template-columns:repeat(2,1fr)}
}
@media (max-width:860px){
  .nav-links,.nav-cta{display:none}
  .nav-toggle{display:flex}
  .hero-grid{grid-template-columns:1fr;gap:2.5rem}
  .hero{min-height:auto;padding:7rem 0 4rem}
  .phone{display:none}
  .dash-stats,.dash-thumbs{gap:.45rem}
  .sec-head{grid-template-columns:1fr;gap:1rem;align-items:start}
  .svc-inner{grid-template-columns:1fr;gap:2.4rem}
  .svc-inner.reverse .svc-copy{order:0}
  .svc-art{min-height:320px}
  .portal{grid-template-columns:1fr;gap:2.2rem}
  .quotes{grid-template-columns:1fr}
  .sticky-cta{display:block}
  .faq{grid-template-columns:1fr}
  .cd-inner{grid-template-columns:1fr;gap:3rem}
  .cd-visual{min-height:300px;max-width:360px}
  .intro-grid{grid-template-columns:1fr}
  .intro-art{justify-self:center;max-width:300px}
  .whatwedo .wwd-row.offset{padding-left:0}
  .wwd{flex:1 1 100%}
  .book-frame{height:min(86vh,820px);border-radius:18px}
  .print-stack{min-height:300px}
}
@media (max-width:560px){
  body{font-size:16px}
  .work-grid{columns:1}
  .pc-grid{grid-template-columns:repeat(2,1fr)}
  .plan-grid{grid-template-columns:1fr}
  .svc-art{min-height:280px}
  .float-img{width:58%}
  .btn{width:100%;justify-content:center}
  .hero-actions,.cta-actions{width:100%}
  .trust{gap:.5rem}.trust b{font-size:1.05rem}
}
