/* ==========================================================================
   Milne & Associates , hand-built. No framework, no component kit.
   Palette: gold #C9A24B / near-black #0D0E11 / oxblood #5F1D23 / cream #F2ECDF
   ========================================================================== */
:root{
  --gold:#c9a24b; --gold-lite:#e6cf94; --gold-deep:#a3781f;
  --black:#0d0e11; --panel:#101116; --panel-2:#14151b; --line:#2a2d36; --muted:#9c958a;
  --ox:#5f1d23; --ox-lite:#7a2a31;
  --cream:#f2ecdf; --cream-deep:#e9e1d0; --ink:#15161a; --cream-muted:#6b6258;
  --serif:'Cinzel',serif; --ui:'Inter',sans-serif;
  --maxw:1200px; --gut:clamp(22px,5vw,80px);
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;background:var(--black);color:#cdc6ba;font-family:var(--ui);font-size:17px;line-height:1.65;-webkit-font-smoothing:antialiased;overflow-x:hidden}
a{color:inherit;text-decoration:none}
h1,h2,h3{margin:0;font-weight:600;letter-spacing:.01em}
img{max-width:100%;display:block}

.grain{position:fixed;inset:0;pointer-events:none;z-index:9;opacity:.05;mix-blend-mode:overlay;
  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='0.8' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");}

/* shared type */
.eyebrow{font-size:.72rem;letter-spacing:.34em;text-transform:uppercase;font-weight:600;color:var(--muted);margin:0}
.eyebrow.gold{color:var(--gold)} .eyebrow.ox{color:var(--ox)}
.display{font-family:var(--serif);font-weight:600;letter-spacing:.02em;line-height:.98;font-size:clamp(3.4rem,11vw,8.5rem);color:var(--gold)}
.h2{font-family:var(--serif);font-weight:600;font-size:clamp(1.8rem,4.4vw,3.2rem);line-height:1.06;color:#efe7d6;letter-spacing:.015em}
.sec-head{margin-bottom:clamp(28px,5vh,56px)}
.sec-head .eyebrow{margin-bottom:14px}

/* ---------- header ---------- */
.site{position:sticky;top:0;z-index:20;display:flex;align-items:center;justify-content:space-between;
  padding:18px var(--gut);background:rgba(13,14,17,.72);backdrop-filter:blur(10px);border-bottom:1px solid rgba(255,255,255,.06)}
.brand{font-family:var(--serif);font-weight:600;font-size:1.5rem;letter-spacing:.12em;color:var(--gold)}
.brand .dot,.foot-brand .dot{color:var(--gold)}
.nav{display:flex;align-items:center;gap:clamp(16px,3vw,38px)}
.nav a{font-size:.82rem;letter-spacing:.12em;text-transform:uppercase;font-weight:500;color:#b7b0a4}
.nav a:hover{color:var(--gold)}
.btn-ghost{border:1px solid var(--gold);color:var(--gold)!important;padding:9px 18px}
.btn-ghost:hover{background:var(--gold);color:var(--black)!important}

/* ---------- buttons ---------- */
.btn{display:inline-block;background:var(--gold);color:#241a05;font-weight:600;font-size:.96rem;padding:15px 30px;
  letter-spacing:.01em;transition:background .2s,transform .2s;border:none;cursor:pointer}
.btn:hover{background:var(--gold-lite);transform:translateY(-1px)}
.btn-line{color:#e3dccd;font-weight:500;font-size:.96rem;padding:15px 6px;border-bottom:1px solid var(--ox-lite)}
.btn-line:hover{border-color:var(--gold);color:#fff}

/* ---------- hero ---------- */
.hero{position:relative;padding:clamp(70px,15vh,160px) var(--gut) clamp(64px,12vh,130px);max-width:var(--maxw);margin:0 auto;overflow:hidden}
.hero-m{position:absolute;right:-8%;top:48%;transform:translateY(-50%);width:min(58vw,720px);height:auto;opacity:.07;pointer-events:none}
.hero-inner{position:relative;max-width:60ch}
.hero .eyebrow{margin-bottom:26px}
.hero .display{margin:0 0 28px}
.lead{font-size:clamp(1.12rem,2.1vw,1.5rem);line-height:1.5;color:#d7d0c4;max-width:34ch;margin:0 0 40px;font-weight:400}
.cta-row{display:flex;flex-wrap:wrap;gap:16px;align-items:center;margin-bottom:54px}
.capline{font-size:.74rem;letter-spacing:.24em;text-transform:uppercase;color:var(--muted);font-weight:500;margin:0}
.capline i{color:var(--gold);font-style:normal;margin:0 5px}

/* ---------- services , editorial rows ---------- */
.services{max-width:var(--maxw);margin:0 auto;padding:clamp(40px,8vh,90px) var(--gut) clamp(60px,12vh,120px)}
.rows{list-style:none;margin:0;padding:0;border-top:1px solid var(--line)}
.row{display:grid;grid-template-columns:auto 1fr auto;gap:clamp(20px,5vw,64px);align-items:baseline;
  padding:clamp(24px,4vh,42px) 0;border-bottom:1px solid var(--line);transition:padding-left .25s}
.row:hover{padding-left:10px}
.num{font-family:var(--serif);font-size:clamp(1.1rem,2vw,1.5rem);color:var(--gold-deep);font-weight:500;letter-spacing:.05em}
.row:hover .num{color:var(--gold)}
.row-title{font-family:var(--serif);font-size:clamp(1.4rem,3.2vw,2.3rem);color:#efe7d6;font-weight:600;margin-bottom:10px;letter-spacing:.01em}
.row-text{color:var(--muted);max-width:56ch;margin:0;font-size:1.02rem}
.row-tag{align-self:center;font-size:.66rem;letter-spacing:.2em;text-transform:uppercase;color:#7c766b;font-weight:600;white-space:nowrap}

/* ---------- work ---------- */
.work{max-width:var(--maxw);margin:0 auto;padding:clamp(40px,8vh,90px) var(--gut) clamp(60px,12vh,120px)}
.work-grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(18px,2.4vw,30px)}
.case{border:1px solid var(--line);background:var(--panel);display:flex;flex-direction:column;transition:border-color .25s,transform .25s}
.case:hover{border-color:rgba(201,162,75,.4);transform:translateY(-3px)}
.case-visual{position:relative;aspect-ratio:16/9;display:flex;align-items:center;justify-content:center;overflow:hidden;border-bottom:1px solid var(--line)}
.case-visual.ai{background:radial-gradient(120% 120% at 70% 20%,#16171d,#0c0d10)}
.case-visual.ai svg{width:118px;height:118px;opacity:.5}
.case-kicker{position:absolute;left:14px;bottom:12px;z-index:3;background:rgba(13,14,17,.82);padding:5px 11px;font-size:.58rem;letter-spacing:.18em;text-transform:uppercase;color:var(--gold);font-weight:600;backdrop-filter:blur(2px)}
.case-visual.shot{background:linear-gradient(160deg,#1a1c22,#0c0d10);flex-direction:column;align-items:stretch;justify-content:flex-start}
.shot-page{position:absolute;inset:32px 0 0;display:block;overflow:hidden}
.shot-page img{width:100%;height:100%;object-fit:cover;object-position:top center;display:block}
.shot-page.no-img{display:flex;align-items:center;justify-content:center}
.shot-page.no-img img{display:none}
.shot-page.no-img::after{content:attr(data-shot);font-family:var(--serif);font-size:1.4rem;color:#3a3d46;letter-spacing:.06em}
.browser-bar{display:flex;align-items:center;gap:6px;height:32px;padding:0 12px;background:#191b21;border-bottom:1px solid #23252d}
.browser-bar i{width:8px;height:8px;border-radius:50%;background:#34373f}
.browser-bar b{margin-left:12px;font-weight:500;font-size:.7rem;color:#6e6a63;letter-spacing:.02em}
.case-body{padding:24px 26px 28px}
.case-title{font-family:var(--serif);font-size:1.4rem;color:#efe7d6;font-weight:600;margin-bottom:5px}
.case-sector{font-size:.74rem;letter-spacing:.14em;text-transform:uppercase;color:var(--gold-deep);font-weight:600;margin:0 0 14px}
.case-text{color:var(--muted);font-size:.98rem;margin:0;line-height:1.6}

/* ---------- process (cream) ---------- */
.process{background:var(--cream);color:var(--ink);padding:clamp(60px,11vh,120px) var(--gut)}
.process>*{max-width:var(--maxw);margin-left:auto;margin-right:auto}
.process .eyebrow{color:var(--ox)} .process .h2{color:var(--ink)}
.steps{display:grid;grid-template-columns:repeat(4,1fr);gap:clamp(20px,3vw,40px)}
.step{border-top:1px solid rgba(95,29,35,.25);padding-top:20px}
.step .num{font-family:var(--serif);font-size:1.5rem;color:var(--ox);font-weight:600;display:block;margin-bottom:14px}
.step h3{font-family:var(--serif);font-size:1.15rem;color:var(--ink);margin-bottom:8px;font-weight:600}
.step p{color:var(--cream-muted);font-size:.95rem;margin:0;line-height:1.55}

/* ---------- pricing ---------- */
.pricing{max-width:var(--maxw);margin:0 auto;padding:clamp(50px,10vh,110px) var(--gut)}
.tiers{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(16px,2vw,24px)}
.tier{position:relative;border:1px solid var(--line);background:var(--panel);padding:34px 30px 32px;display:flex;flex-direction:column}
.tier.featured{border-color:var(--gold);background:linear-gradient(180deg,#15151a,#0f1014)}
.tier-flag{position:absolute;top:-1px;right:18px;transform:translateY(-50%);background:var(--gold);color:#241a05;font-size:.6rem;letter-spacing:.16em;text-transform:uppercase;font-weight:700;padding:5px 12px}
.tier-name{font-size:.78rem;letter-spacing:.18em;text-transform:uppercase;color:var(--muted);font-weight:600;margin:0 0 16px}
.tier-price{font-family:var(--serif);font-size:2.1rem;color:var(--gold);font-weight:600;margin:0 0 18px;line-height:1}
.tier-price span{font-family:var(--ui);font-size:.9rem;color:var(--muted);font-weight:400;letter-spacing:.02em}
.tier-text{color:var(--muted);font-size:.96rem;line-height:1.6;margin:0 0 26px;flex:1}
.tier-cta{align-self:flex-start;border:1px solid var(--line);color:#e3dccd;font-weight:600;font-size:.86rem;padding:11px 22px;transition:.2s}
.tier-cta:hover{border-color:var(--gold);color:var(--gold)}
.tier-cta.gold{background:var(--gold);color:#241a05;border-color:var(--gold)}
.tier-cta.gold:hover{background:var(--gold-lite)}
.pricing-note{text-align:center;color:#7c766b;font-size:.86rem;margin:30px 0 0}

/* ---------- about (cream) ---------- */
.about{background:var(--cream);color:var(--ink);padding:clamp(60px,12vh,130px) var(--gut)}
.about-grid{max-width:var(--maxw);margin:0 auto;display:grid;grid-template-columns:1.5fr 1fr;gap:clamp(36px,6vw,80px);align-items:center}
.about-statement{font-family:var(--serif);font-weight:600;font-size:clamp(1.7rem,4vw,2.9rem);line-height:1.1;color:var(--ink);max-width:18ch;margin:22px 0 26px;letter-spacing:.01em}
.about-body{font-size:clamp(1.02rem,1.5vw,1.18rem);line-height:1.65;color:#5c5347;max-width:54ch;margin:0 0 16px}
.about-portrait{display:flex;justify-content:center}
.portrait-frame{width:100%;max-width:320px;aspect-ratio:4/5;border:1px solid var(--ox);background:linear-gradient(160deg,#e6ddcb,#d8cdb6);
  display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;color:var(--ox)}
.portrait-frame span{font-family:var(--serif);font-size:1.1rem;letter-spacing:.06em}
.portrait-frame small{font-size:.66rem;letter-spacing:.22em;text-transform:uppercase;color:#9a8f78}
.about-portrait img{width:100%;max-width:320px;aspect-ratio:4/5;object-fit:cover;border:1px solid var(--ox)}

/* ---------- contact ---------- */
.contact{max-width:var(--maxw);margin:0 auto;padding:clamp(56px,11vh,120px) var(--gut)}
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(36px,6vw,80px)}
.contact .h2{margin:14px 0 18px}
.contact-lead{color:var(--muted);font-size:1.05rem;max-width:36ch;margin:0 0 28px}
.contact-direct a{color:var(--gold);font-weight:500;line-height:1.9}
.contact-direct a:hover{color:var(--gold-lite)}
.contact-form{display:grid;gap:16px}
.field{display:flex;flex-direction:column;gap:7px}
.field span{font-size:.7rem;letter-spacing:.16em;text-transform:uppercase;color:var(--muted);font-weight:600}
.field input,.field select,.field textarea{background:var(--panel);border:1px solid var(--line);color:#e3dccd;
  font-family:var(--ui);font-size:.98rem;padding:12px 14px;border-radius:0;transition:border-color .2s}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--gold)}
.field textarea{resize:vertical}
.contact-form .btn{justify-self:start;margin-top:6px}
.hp{position:absolute;left:-9999px}

/* ---------- footer ---------- */
.site-foot{padding:clamp(56px,10vh,110px) var(--gut) 50px;max-width:var(--maxw);margin:0 auto;border-top:1px solid var(--line)}
.foot-top{display:flex;justify-content:space-between;align-items:flex-end;gap:30px;flex-wrap:wrap;margin-bottom:40px}
.foot-brand{font-family:var(--serif);font-weight:600;font-size:clamp(2.4rem,7vw,4rem);color:var(--gold);letter-spacing:.1em;line-height:1}
.foot-tag{font-size:.72rem;letter-spacing:.32em;text-transform:uppercase;color:var(--gold-deep);font-weight:600;margin:12px 0 0}
.foot-nav{display:flex;gap:26px;flex-wrap:wrap}
.foot-nav a{font-size:.8rem;letter-spacing:.12em;text-transform:uppercase;color:#b7b0a4;font-weight:500}
.foot-nav a:hover{color:var(--gold)}
.foot-meta{color:#7c766b;font-size:.86rem;margin:0;border-top:1px solid var(--line);padding-top:26px}

/* ---------- responsive ---------- */
@media(max-width:820px){
  .work-grid{grid-template-columns:1fr}
  .steps{grid-template-columns:1fr 1fr;gap:28px}
  .tiers{grid-template-columns:1fr;max-width:440px;margin:0 auto}
  .about-grid,.contact-grid{grid-template-columns:1fr}
  .about-portrait{order:-1}
}
@media(max-width:680px){
  .nav a:not(.btn-ghost){display:none}
  .row{grid-template-columns:auto 1fr;gap:18px}
  .row-tag{display:none}
  .steps{grid-template-columns:1fr}
  .hero-m{opacity:.05}
}

/* ---------- service pages ---------- */
.rowlink{display:contents;color:inherit}
.svc-hero{position:relative;max-width:var(--maxw);margin:0 auto;padding:clamp(64px,13vh,130px) var(--gut) clamp(40px,7vh,72px);overflow:hidden}
.svc-hero .hero-m{position:absolute;right:-8%;top:50%;transform:translateY(-50%);width:min(52vw,620px);opacity:.06}
.svc-eyebrow{font-size:.72rem;letter-spacing:.3em;text-transform:uppercase;font-weight:600;color:var(--gold);margin:0 0 22px}
.svc-h1{font-family:var(--serif);font-weight:600;font-size:clamp(2.4rem,6vw,4.4rem);line-height:1.02;color:var(--gold);letter-spacing:.01em;margin:0 0 26px;max-width:17ch;position:relative}
.svc-lead{font-size:clamp(1.1rem,2vw,1.4rem);line-height:1.5;color:#d7d0c4;max-width:42ch;margin:0 0 36px;position:relative}
.svc-hero .cta-row{position:relative}
.svc-block{max-width:var(--maxw);margin:0 auto;padding:clamp(46px,9vh,96px) var(--gut);border-top:1px solid var(--line)}
.svc-block h2{font-family:var(--serif);font-weight:600;font-size:clamp(1.7rem,3.8vw,2.7rem);color:#efe7d6;margin:0 0 24px;letter-spacing:.01em;max-width:20ch}
.svc-block .big{font-size:clamp(1.05rem,1.7vw,1.25rem);line-height:1.65;color:#bdb6aa;max-width:64ch;margin:0}
.svc-cream{background:var(--cream);border-top:none}
.svc-cream h2{color:var(--ink)} .svc-cream .big{color:#5c5347} .svc-cream .svc-eyebrow{color:var(--ox)}
.ticks{list-style:none;margin:30px 0 0;padding:0;display:grid;grid-template-columns:1fr 1fr;gap:16px 44px;max-width:900px}
.ticks li{position:relative;padding-left:26px;color:#cdc6ba;line-height:1.5}
.ticks li::before{content:"";position:absolute;left:2px;top:.5em;width:8px;height:8px;background:var(--gold);transform:rotate(45deg)}
.svc-cream .ticks li{color:#5c5347}
.svc-cream .ticks li::before{background:var(--ox)}
.hiw{display:grid;grid-template-columns:repeat(4,1fr);gap:clamp(20px,3vw,40px);margin-top:8px}
.hiw .s{border-top:1px solid var(--line);padding-top:20px}
.hiw .n{font-family:var(--serif);font-size:1.4rem;color:var(--gold);display:block;margin-bottom:12px;font-weight:600}
.hiw h3{font-family:var(--serif);font-size:1.05rem;color:#efe7d6;margin:0 0 8px;font-weight:600}
.hiw p{color:var(--muted);font-size:.95rem;margin:0;line-height:1.5}
.faq{max-width:800px;margin:26px 0 0}
.faq-item{border-top:1px solid var(--line);padding:22px 0}
.faq-item h3{font-family:var(--serif);font-weight:600;font-size:1.18rem;color:#efe7d6;margin:0 0 9px}
.faq-item p{color:var(--muted);margin:0;line-height:1.6;max-width:64ch}
.cta-band{text-align:center;padding:clamp(58px,11vh,120px) var(--gut);border-top:1px solid var(--line)}
.cta-band h2{font-family:var(--serif);font-weight:600;font-size:clamp(2rem,5vw,3.4rem);color:var(--gold);margin:0 0 16px}
.cta-band p{color:#bdb6aa;max-width:48ch;margin:0 auto 30px;font-size:1.05rem}
.cta-band .wa-btn{margin:0 auto}
.svc-backlinks{display:flex;gap:22px;flex-wrap:wrap;margin-top:30px}
.svc-backlinks a{font-size:.8rem;letter-spacing:.1em;text-transform:uppercase;color:var(--muted);font-weight:500;border-bottom:1px solid var(--ox-lite);padding-bottom:3px}
.svc-backlinks a:hover{color:var(--gold);border-color:var(--gold)}
@media(max-width:760px){.ticks{grid-template-columns:1fr}.hiw{grid-template-columns:1fr 1fr}}
@media(max-width:480px){.hiw{grid-template-columns:1fr}}

/* service pages , editorial dossier (v2) */
.svc-sec{display:grid;grid-template-columns:minmax(120px,210px) 1fr;gap:clamp(26px,6vw,88px);max-width:var(--maxw);margin:0 auto;padding:clamp(56px,10vh,112px) var(--gut);border-top:1px solid var(--line);align-items:start}
.svc-sec.cream{background:var(--cream);border-top:none}
.svc-marker .idx{font-family:var(--serif);font-size:clamp(2rem,3.6vw,3.3rem);color:var(--gold-deep);font-weight:600;line-height:1;display:block}
.svc-marker .lbl{font-size:.68rem;letter-spacing:.26em;text-transform:uppercase;color:var(--muted);font-weight:600;margin-top:14px;display:block}
.svc-sec.cream .svc-marker .idx{color:var(--ox)} .svc-sec.cream .svc-marker .lbl{color:#9a8f78}
.statement{font-family:var(--serif);font-weight:600;font-size:clamp(1.9rem,4.2vw,3.1rem);line-height:1.1;color:#efe7d6;letter-spacing:.01em;margin:0;max-width:21ch}
.svc-sec.cream .statement{color:var(--ink)}
.statement .ac{color:var(--gold)} .svc-sec.cream .statement .ac{color:var(--ox)}
.prose{font-size:clamp(1.05rem,1.6vw,1.2rem);line-height:1.65;color:#bdb6aa;max-width:60ch;margin:22px 0 0}
.svc-sec.cream .prose{color:#5c5347}
.caps{margin:34px 0 0;border-top:1px solid var(--line)}
.cap{display:grid;grid-template-columns:auto 1fr;gap:22px;padding:19px 0;border-bottom:1px solid var(--line);align-items:baseline}
.cap .d{width:7px;height:7px;background:var(--gold);transform:rotate(45deg);margin-top:.5em}
.cap b{font-family:var(--serif);font-weight:600;color:#efe7d6;font-size:1.1rem}
.cap em{color:var(--muted);font-size:.95rem;font-style:normal;display:block;margin-top:4px;line-height:1.5}
.flow{margin-top:6px}
.flow .st{display:grid;grid-template-columns:auto 1fr;gap:24px;padding:20px 0;border-bottom:1px solid var(--line);align-items:baseline}
.flow .st:first-child{border-top:1px solid var(--line)}
.flow .sn{font-family:var(--serif);font-size:1.35rem;color:var(--gold-deep);font-weight:600}
.flow h3{font-family:var(--serif);color:#efe7d6;font-size:1.18rem;margin:0 0 5px;font-weight:600}
.flow p{color:var(--muted);margin:0;font-size:.96rem;line-height:1.5}
.svc-faq .faq-item:first-child{border-top:1px solid var(--line)}
@media(max-width:820px){.svc-sec{grid-template-columns:1fr;gap:16px}.svc-marker{display:flex;align-items:baseline;gap:16px}.svc-marker .lbl{margin-top:0}}

/* ---------- additions: linked cases, whatsapp, photo fallback ---------- */
.case{color:inherit}
.case .ext{font-size:.62em;color:var(--gold-deep);margin-left:5px;vertical-align:top}
.case:hover .ext{color:var(--gold)}
.case:hover .case-title{color:#fff}

.wa-btn{display:inline-flex;align-items:center;gap:11px;background:var(--gold);color:#241a05;font-weight:600;font-size:1rem;padding:15px 26px;margin:6px 0 22px;transition:background .2s,transform .2s}
.wa-btn:hover{background:var(--gold-lite);transform:translateY(-1px)}
.wa-btn svg{width:21px;height:21px}
.form-or{font-size:.72rem;letter-spacing:.16em;text-transform:uppercase;color:var(--muted);font-weight:600;margin:0 0 2px}

.portrait-img{width:100%;max-width:320px;aspect-ratio:4/5;object-fit:cover;object-position:center;border:1px solid var(--ox);display:block}
.portrait-frame{display:none}
.about-portrait.no-img .portrait-img{display:none}
.about-portrait.no-img .portrait-frame{display:flex}
