/* ===== ASK Advertising — mockup design system ===== */
@import url('https://fonts.googleapis.com/css2?family=Bricolage+Grotesque:opsz,wght@12..96,400;12..96,500;12..96,600;12..96,700;12..96,800&family=Hanken+Grotesk:ital,wght@0,400;0,500;0,600;0,700;1,400&family=Caveat:wght@500;600;700&display=swap');

:root{
  --plum:#8B3F66;
  --plum-deep:#4E2238;
  --plum-soft:#B97C9C;
  --sage:#8C9A6A;
  --sage-deep:#5F6E43;
  --cream:#F4F2E4;
  --cream-2:#ECE8D6;
  --ink:#241C20;
  --grey:#6A6168;
  --line:rgba(36,28,32,.14);
  --maxw:1320px;
  --r:18px;
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  font-family:'Hanken Grotesk',sans-serif;
  background:var(--cream);
  color:var(--ink);
  line-height:1.55;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
/* subtle paper grain */
body::before{
  content:"";position:fixed;inset:0;pointer-events:none;z-index:1;opacity:.04;mix-blend-mode:multiply;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}

h1,h2,h3,h4{font-family:'Bricolage Grotesque',sans-serif;font-weight:700;line-height:.98;letter-spacing:-.02em}
.script{font-family:'Caveat',cursive;font-weight:600;letter-spacing:0}

.wrap{max-width:var(--maxw);margin:0 auto;padding:0 40px;position:relative;z-index:2}
.eyebrow{font-family:'Hanken Grotesk';font-weight:700;text-transform:uppercase;letter-spacing:.22em;font-size:12px;color:var(--sage-deep)}
.eyebrow.on-dark{color:var(--plum-soft)}

/* ===== Buttons ===== */
.btn{display:inline-flex;align-items:center;gap:.6em;font-weight:600;font-size:15px;padding:15px 26px;border-radius:100px;transition:.25s ease;cursor:pointer;border:1.5px solid transparent}
.btn .arr{transition:transform .25s ease}
.btn:hover .arr{transform:translateX(4px)}
.btn-plum{background:var(--plum);color:#fff}
.btn-plum:hover{background:var(--plum-deep)}
.btn-ghost{border-color:var(--ink);color:var(--ink)}
.btn-ghost:hover{background:var(--ink);color:var(--cream)}
.btn-cream{background:var(--cream);color:var(--plum-deep)}
.btn-cream:hover{background:#fff}

/* ===== Nav ===== */
.nav{position:sticky;top:0;z-index:50;backdrop-filter:blur(10px);background:rgba(244,242,228,.82);border-bottom:1px solid var(--line)}
.nav-in{display:flex;align-items:center;justify-content:space-between;height:84px}
.nav .logo img{height:46px}
.nav-links{display:flex;gap:34px;align-items:center}
.nav-links a{font-weight:600;font-size:15px;color:var(--ink);position:relative;padding:4px 0}
.nav-links a::after{content:"";position:absolute;left:0;bottom:-2px;width:0;height:2px;background:var(--plum);transition:width .25s}
.nav-links a:hover::after,.nav-links a.active::after{width:100%}
.nav-links a.active{color:var(--plum)}

/* ===== generic section ===== */
section{position:relative;z-index:2}
.sec{padding:120px 0}
.sec-sm{padding:80px 0}
.section-head{max-width:720px;margin-bottom:54px}
.section-head h2{font-size:clamp(36px,5vw,64px);margin:14px 0 0}
.lead{font-size:20px;color:var(--grey);max-width:620px}

/* giant ? motif */
.qmark{font-family:'Bricolage Grotesque';font-weight:800;color:var(--plum);line-height:.7;pointer-events:none}

/* ===== HERO ===== */
.hero{padding:90px 0 70px;position:relative;overflow:hidden}
.hero .big{font-size:clamp(60px,12.5vw,178px);letter-spacing:-.035em;color:var(--ink)}
.hero .big em{font-style:normal;color:var(--plum)}
.hero-kicker{display:inline-flex;align-items:center;gap:10px;font-weight:600;color:var(--sage-deep);font-size:15px;margin-bottom:28px}
.hero-kicker .dot{width:8px;height:8px;border-radius:50%;background:var(--sage)}
.hero-bottom{display:flex;justify-content:space-between;align-items:flex-end;gap:40px;margin-top:40px;flex-wrap:wrap}
.hero-bottom p{max-width:440px;font-size:19px;color:var(--grey)}
.hero-cta{display:flex;gap:14px;flex-wrap:wrap}
.hero-q{position:absolute;right:-30px;top:-40px;font-size:560px;color:rgba(139,63,102,.07);font-family:'Bricolage Grotesque';font-weight:800;z-index:-0}
.hero .script-accent{font-family:'Caveat';color:var(--plum);font-size:.32em;transform:rotate(-6deg);display:inline-block;vertical-align:super}

/* ===== marquee ===== */
.marquee{border-top:1px solid var(--line);border-bottom:1px solid var(--line);padding:26px 0;overflow:hidden;background:var(--cream-2)}
.marquee .track{display:flex;gap:64px;white-space:nowrap;animation:scroll 32s linear infinite;width:max-content}
.marquee span{font-family:'Bricolage Grotesque';font-weight:600;font-size:24px;color:var(--ink);opacity:.55}
@keyframes scroll{to{transform:translateX(-50%)}}

/* ===== intro statement ===== */
.statement{font-size:clamp(28px,3.6vw,48px);font-family:'Bricolage Grotesque';font-weight:600;line-height:1.12;letter-spacing:-.02em;max-width:1000px}
.statement b{color:var(--plum)}

/* ===== services grid ===== */
.svc-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.svc{background:#fff;border:1px solid var(--line);border-radius:var(--r);padding:34px 30px 30px;position:relative;overflow:hidden;transition:.3s}
.svc:hover{transform:translateY(-6px);box-shadow:0 26px 50px -28px rgba(78,34,56,.45);border-color:transparent}
.svc .num{font-family:'Bricolage Grotesque';font-weight:700;color:var(--sage);font-size:15px;letter-spacing:.05em}
.svc h3{font-size:26px;margin:18px 0 12px}
.svc p{color:var(--grey);font-size:15.5px}
.svc .tags{margin-top:18px;display:flex;flex-wrap:wrap;gap:8px}
.svc .tags span{font-size:12.5px;font-weight:600;color:var(--plum-deep);background:var(--cream-2);padding:6px 12px;border-radius:100px}
.svc .ghost-q{position:absolute;right:-12px;bottom:-46px;font-size:150px;color:rgba(139,63,102,.06);font-family:'Bricolage Grotesque';font-weight:800}

/* ===== work / portfolio ===== */
.work-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:20px}
.work-grid.three{grid-template-columns:repeat(3,1fr)}
.proj{border-radius:var(--r);overflow:hidden;position:relative;aspect-ratio:4/3;display:flex;flex-direction:column;justify-content:flex-end;padding:30px;color:#fff;transition:.35s}
.proj:hover{transform:translateY(-6px)}
.proj::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(0,0,0,0) 30%,rgba(0,0,0,.55));z-index:1}
.proj>*{position:relative;z-index:2}
.proj .cat{font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.18em;opacity:.9}
.proj h3{font-size:30px;margin-top:8px}
.proj p{font-size:14.5px;opacity:.92;margin-top:8px;max-width:90%}
.g1{background:linear-gradient(135deg,#8B3F66,#4E2238)}
.g2{background:linear-gradient(135deg,#5F6E43,#2f3a22)}
.g3{background:linear-gradient(135deg,#B97C9C,#6d3450)}
.g4{background:linear-gradient(135deg,#3a3033,#241C20)}
.g5{background:linear-gradient(135deg,#8C9A6A,#525f38)}
.g6{background:linear-gradient(135deg,#a85c83,#4E2238)}
.proj .wm{position:absolute;right:-10px;top:-30px;font-size:170px;font-family:'Bricolage Grotesque';font-weight:800;color:rgba(255,255,255,.09);z-index:1}

/* ===== stats ===== */
.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:30px;border-top:1px solid var(--line);border-bottom:1px solid var(--line);padding:56px 0}
.stat .n{font-family:'Bricolage Grotesque';font-weight:700;font-size:62px;color:var(--plum);line-height:1}
.stat .l{color:var(--grey);font-weight:500;margin-top:6px}

/* ===== dark quote band ===== */
.band{background:var(--plum-deep);color:var(--cream);position:relative;overflow:hidden}
.band .wrap{padding:120px 40px}
.band .qmark{position:absolute;right:2%;top:-80px;font-size:440px;color:rgba(255,255,255,.06)}
.band blockquote{font-family:'Bricolage Grotesque';font-weight:600;font-size:clamp(30px,4.2vw,58px);line-height:1.08;letter-spacing:-.02em;max-width:1000px}
.band blockquote b{color:var(--plum-soft)}
.band cite{display:block;margin-top:30px;font-style:normal;font-weight:600;color:var(--plum-soft);letter-spacing:.04em}

/* ===== CTA ===== */
.cta{text-align:center;padding:130px 0}
.cta h2{font-size:clamp(48px,9vw,128px);color:var(--plum);letter-spacing:-.04em}
.cta .script{color:var(--sage-deep);font-size:clamp(30px,5vw,60px);display:block;transform:rotate(-3deg);margin-bottom:-6px}
.cta p{font-size:20px;color:var(--grey);margin:22px auto 34px;max-width:520px}

/* ===== footer ===== */
.footer{background:var(--ink);color:var(--cream);padding:80px 0 40px}
.footer-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1.2fr;gap:40px}
.footer h4{font-size:14px;text-transform:uppercase;letter-spacing:.16em;color:var(--plum-soft);margin-bottom:18px;font-family:'Hanken Grotesk';font-weight:700}
.footer a,.footer li{color:rgba(244,242,228,.72);font-size:15px;line-height:2.1;list-style:none}
.footer a:hover{color:#fff}
.footer .brand .script{font-size:40px;color:var(--cream)}
.footer .brand p{color:rgba(244,242,228,.6);margin-top:10px;max-width:280px;font-size:15px}
.footer-bottom{border-top:1px solid rgba(255,255,255,.12);margin-top:54px;padding-top:24px;display:flex;justify-content:space-between;color:rgba(244,242,228,.5);font-size:13.5px;flex-wrap:wrap;gap:10px}

/* ===== page hero (inner) ===== */
.phero{padding:80px 0 60px;position:relative;overflow:hidden}
.phero h1{font-size:clamp(52px,8.5vw,118px);color:var(--ink);letter-spacing:-.035em}
.phero h1 em{font-style:normal;color:var(--plum)}
.phero .lead{margin-top:24px;font-size:21px}
.phero .qmark{position:absolute;right:-20px;top:-60px;font-size:420px;color:rgba(139,63,102,.06)}

/* ===== services detail rows ===== */
.svc-row{display:grid;grid-template-columns:80px 1fr 1.1fr;gap:36px;align-items:start;padding:46px 0;border-top:1px solid var(--line)}
.svc-row .idx{font-family:'Bricolage Grotesque';font-weight:700;font-size:40px;color:var(--sage)}
.svc-row h3{font-size:34px}
.svc-row .desc{color:var(--grey);font-size:16px;margin-top:12px}
.svc-row ul{list-style:none;columns:2;gap:24px}
.svc-row li{font-weight:500;padding:9px 0;border-bottom:1px dashed var(--line);font-size:15.5px;break-inside:avoid}
.svc-row li::before{content:"?";color:var(--plum);font-family:'Bricolage Grotesque';font-weight:700;margin-right:10px}

/* ===== about ===== */
.about-quote{font-family:'Bricolage Grotesque';font-weight:600;font-size:clamp(30px,4.4vw,60px);line-height:1.06;letter-spacing:-.02em;max-width:1100px}
.about-quote b{color:var(--plum)}
.steps{display:grid;grid-template-columns:repeat(4,1fr);gap:18px}
.step{background:#fff;border:1px solid var(--line);border-radius:var(--r);padding:30px;position:relative}
.step .k{font-family:'Caveat';font-size:30px;color:var(--plum)}
.step h3{font-size:24px;margin:6px 0 10px}
.step p{color:var(--grey);font-size:15px}
.md-card{background:var(--cream-2);border-radius:var(--r);padding:48px;display:grid;grid-template-columns:auto 1fr;gap:36px;align-items:center}
.md-card .avatar{width:120px;height:120px;border-radius:50%;background:linear-gradient(135deg,var(--plum),var(--plum-deep));display:flex;align-items:center;justify-content:center;font-family:'Bricolage Grotesque';font-weight:700;color:#fff;font-size:42px}
.md-card .q{font-family:'Bricolage Grotesque';font-weight:600;font-size:24px;line-height:1.25}
.md-card .who{margin-top:14px;font-weight:600}.md-card .who span{color:var(--grey);font-weight:500}

/* sectors */
.sectors{display:flex;flex-wrap:wrap;gap:12px}
.sectors span{border:1.5px solid var(--line);border-radius:100px;padding:12px 22px;font-weight:600;color:var(--plum-deep)}

/* ===== contact ===== */
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:start}
.cinfo .row{padding:22px 0;border-top:1px solid var(--line)}
.cinfo .row .k{font-size:13px;text-transform:uppercase;letter-spacing:.16em;color:var(--sage-deep);font-weight:700}
.cinfo .row .v{font-family:'Bricolage Grotesque';font-weight:600;font-size:24px;margin-top:6px}
.form{background:#fff;border:1px solid var(--line);border-radius:var(--r);padding:40px}
.form label{display:block;font-weight:600;font-size:14px;margin:18px 0 8px}
.form input,.form textarea,.form select{width:100%;border:1.5px solid var(--line);border-radius:12px;padding:14px 16px;font-family:inherit;font-size:15px;background:var(--cream)}
.form textarea{min-height:120px;resize:vertical}
.form .btn{width:100%;justify-content:center;margin-top:26px}

.two-col{display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:center}

@media(max-width:900px){
  .svc-grid,.work-grid.three,.stats,.steps,.footer-grid{grid-template-columns:1fr 1fr}
  .contact-grid,.two-col,.work-grid{grid-template-columns:1fr}
  .svc-row{grid-template-columns:1fr}
}

/* ===== Mobile nav (hamburger) ===== */
.nav-toggle{display:none;width:46px;height:46px;border:none;background:transparent;cursor:pointer;flex-direction:column;justify-content:center;gap:5px;padding:0;z-index:70}
.nav-toggle span{display:block;width:26px;height:2.5px;background:var(--ink);border-radius:2px;transition:.3s;margin:0 auto}
body.nav-open .nav-toggle span{background:var(--cream)}
body.nav-open .nav-toggle span:nth-child(1){transform:translateY(7.5px) rotate(45deg)}
body.nav-open .nav-toggle span:nth-child(2){opacity:0}
body.nav-open .nav-toggle span:nth-child(3){transform:translateY(-7.5px) rotate(-45deg)}

@media(max-width:860px){
  /* backdrop-filter would trap the fixed overlay inside the header — disable on mobile */
  .nav{backdrop-filter:none;-webkit-backdrop-filter:none}
  .nav-toggle{display:flex}
  .nav-links{position:fixed;inset:0;background:var(--plum-deep);flex-direction:column;justify-content:center;align-items:center;gap:30px;transform:translateX(100%);transition:transform .45s cubic-bezier(.7,0,.2,1);z-index:60}
  .nav-links a{color:var(--cream);font-family:'Bricolage Grotesque';font-size:32px;font-weight:600;padding:0}
  .nav-links a::after{display:none}
  .nav-links a.active{color:var(--plum-soft)}
  .nav-links .btn{margin-top:12px;font-size:18px;padding:16px 32px;background:var(--cream);color:var(--plum-deep)}
  body.nav-open .nav-links{transform:none}
  body.nav-open{overflow:hidden}
}

/* ===== Phone layout ===== */
@media(max-width:600px){
  .wrap{padding:0 22px}
  .svc-grid,.work-grid.three,.work-grid,.stats,.steps,.svc-row ul{grid-template-columns:1fr;columns:1}
  .footer-grid{grid-template-columns:1fr 1fr}
  .footer .brand{grid-column:1 / -1}
  .sec{padding:72px 0}.sec-sm{padding:54px 0}
  .section-head{margin-bottom:34px;flex-wrap:wrap;gap:18px}
  .hero .big{font-size:clamp(46px,15vw,82px)}
  .hero{min-height:88vh}
  .stat .n{font-size:46px}
  .band .wrap{padding:80px 22px}
  .md-card{grid-template-columns:1fr;padding:32px;text-align:center;gap:20px}
  .md-card .avatar{margin:0 auto}
  .cta{padding:90px 0}
}


/* ===== Block-editor page content (native blocks) ===== */
.page-content .wp-block-group.alignfull{width:100%;margin-left:0;margin-right:0}
.page-content .phero,.page-content .sec,.page-content .sec-sm,.page-content .band,.page-content .cta{padding-left:0;padding-right:0}
.page-content .wrap>*+*{margin-top:0}


/* ===== 3D hero canvas (homepage) ===== */
#three{position:absolute;right:-2%;top:0;width:58%;height:100%;z-index:1;pointer-events:none}
@media(max-width:860px){#three{width:80%;right:-14%;top:8%;height:60%;opacity:.7}}


/* ===== Custom logo (Site Identity) sizing ===== */
.custom-logo{height:46px;width:auto;display:block}
.custom-logo-link{display:inline-block;line-height:0}

/* ===== Remove custom cursor (use normal pointer) ===== */
body.interactive{cursor:auto!important}
.cursor,.cursor-ring{display:none!important}
