*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;}
:root{--ink:#0e0d0b;--ink2:#5c5a55;--ink3:#a8a49d;--cream:#f8f5f0;--cream2:#ede9e2;--cream3:#e2ddd5;--gold:#b8955a;--gold-light:#f0e6d3;--serif:'Playfair Display',Georgia,serif;--sans:'Outfit',system-ui,sans-serif;--max:1120px;--nav:68px;}
html{scroll-behavior:smooth;}
body{font-family:var(--sans);background:var(--cream);color:var(--ink);font-size:16px;line-height:1.6;-webkit-font-smoothing:antialiased;cursor:none;}
.cursor{position:fixed;width:10px;height:10px;background:var(--gold);border-radius:50%;pointer-events:none;z-index:9999;transform:translate(-50%,-50%);transition:width .3s,height .3s,background .3s;}
.cursor-ring{position:fixed;width:36px;height:36px;border:1px solid rgba(184,149,90,.5);border-radius:50%;pointer-events:none;z-index:9998;transform:translate(-50%,-50%);transition:width .3s,height .3s;}

/* NAV */
nav{position:fixed;top:0;left:0;right:0;height:var(--nav);display:flex;align-items:center;justify-content:space-between;padding:0 52px;background:rgba(248,245,240,.92);backdrop-filter:blur(16px);border-bottom:1px solid rgba(14,13,11,.07);z-index:100;}
.nav-logo{font-family:var(--serif);font-size:19px;letter-spacing:-.01em;color:var(--ink);text-decoration:none;display:flex;align-items:center;gap:10px;}
.nav-dot{width:6px;height:6px;border-radius:50%;background:var(--gold);display:inline-block;}
.nav-links{display:flex;gap:32px;list-style:none;}
.nav-links a{font-size:12px;font-weight:500;letter-spacing:.1em;text-transform:uppercase;color:var(--ink2);text-decoration:none;transition:color .2s;}
.nav-links a:hover{color:var(--ink);}
.nav-cta{font-size:12px;font-weight:500;letter-spacing:.06em;padding:9px 22px;border:1px solid var(--ink);color:var(--ink);text-decoration:none;border-radius:100px;transition:all .22s;}
.nav-cta:hover{background:var(--ink);color:var(--cream);}

/* HERO */
#hero{min-height:100vh;display:flex;flex-direction:column;justify-content:flex-end;padding:calc(var(--nav) + 60px) 52px 80px;position:relative;overflow:hidden;}
.hero-bg-text{position:absolute;top:50%;right:-20px;transform:translateY(-50%);font-family:var(--serif);font-size:clamp(160px,18vw,260px);font-weight:700;font-style:italic;color:transparent;-webkit-text-stroke:1px rgba(184,149,90,.12);pointer-events:none;line-height:1;white-space:nowrap;z-index:0;}
.hero-content{position:relative;z-index:1;max-width:var(--max);margin:0 auto;width:100%;}
.hero-tag{display:inline-flex;align-items:center;gap:10px;font-size:11px;font-weight:500;letter-spacing:.14em;text-transform:uppercase;color:var(--gold);margin-bottom:32px;opacity:0;animation:fadeUp .8s .1s forwards;}
.hero-tag::before{content:'';width:24px;height:1px;background:var(--gold);}
.hero-name{font-family:var(--serif);font-size:clamp(56px,8vw,110px);line-height:.95;letter-spacing:-.03em;font-weight:700;opacity:0;animation:fadeUp .8s .2s forwards;}
.hero-name em{font-style:italic;font-weight:400;color:var(--gold);}
.hero-sub{margin-top:28px;font-size:clamp(15px,1.8vw,19px);font-weight:300;color:var(--ink2);max-width:600px;line-height:1.75;opacity:0;animation:fadeUp .8s .35s forwards;}
.hero-stats{display:flex;gap:48px;margin-top:56px;padding-top:40px;border-top:1px solid rgba(14,13,11,.1);opacity:0;animation:fadeUp .8s .5s forwards;}
.stat-n{font-family:var(--serif);font-size:42px;font-weight:700;letter-spacing:-.02em;line-height:1;}
.stat-n sup{font-size:22px;vertical-align:super;}
.stat-l{font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--ink3);margin-top:6px;}
.hero-btns{display:flex;gap:16px;margin-top:44px;opacity:0;animation:fadeUp .8s .6s forwards;}
.btn{display:inline-flex;align-items:center;gap:8px;padding:14px 30px;font-family:var(--sans);font-size:13px;font-weight:500;letter-spacing:.04em;border-radius:2px;text-decoration:none;transition:all .22s;cursor:none;border:none;}
.btn-dark{background:var(--ink);color:var(--cream);}
.btn-dark:hover{background:var(--gold);}
.btn-out{background:transparent;color:var(--ink);border:1px solid rgba(14,13,11,.25);}
.btn-out:hover{border-color:var(--ink);background:var(--cream2);}

/* MARQUEE */
.mq-wrap{background:var(--ink);padding:18px 0;overflow:hidden;}
.mq-track{display:flex;animation:marquee 26s linear infinite;white-space:nowrap;}
.mi{font-size:12px;letter-spacing:.14em;text-transform:uppercase;color:rgba(248,245,240,.38);padding:0 38px;display:flex;align-items:center;gap:38px;}
.mi::after{content:'✦';color:var(--gold);font-size:8px;}
@keyframes marquee{from{transform:translateX(0);}to{transform:translateX(-50%);}}

/* SHARED */
.sw{padding:110px 52px;max-width:var(--max);margin:0 auto;}
.lbl{font-size:11px;font-weight:500;letter-spacing:.14em;text-transform:uppercase;color:var(--gold);display:flex;align-items:center;gap:12px;margin-bottom:20px;}
.lbl::after{content:'';width:28px;height:1px;background:var(--gold);}
.sh{font-family:var(--serif);font-size:clamp(34px,4vw,52px);letter-spacing:-.025em;line-height:1.07;margin-bottom:16px;}

/* ABOUT */
.about-grid{display:grid;grid-template-columns:1fr 1.1fr;gap:80px;align-items:start;}
.about-photo-wrap{position:relative;}
.about-photo{aspect-ratio:3/4;border-radius:2px;overflow:hidden;background:var(--cream2);}
.about-photo img{width:100%;height:100%;object-fit:cover;display:block;}
.about-photo-deco{position:absolute;bottom:-18px;right:-18px;width:100px;height:100px;border:1px solid rgba(184,149,90,.3);border-radius:2px;pointer-events:none;}
.about-badges{display:flex;flex-wrap:wrap;gap:8px;margin-top:32px;}
.badge{font-size:11px;letter-spacing:.07em;padding:6px 14px;border-radius:100px;background:var(--cream2);color:var(--ink2);border:1px solid var(--cream3);text-transform:uppercase;}
.badge.g{background:var(--gold-light);color:#7a5c28;border-color:rgba(184,149,90,.3);}
.about-txt p{color:var(--ink2);font-weight:300;line-height:1.85;margin-bottom:14px;}
.about-brands{margin-top:36px;padding-top:32px;border-top:1px solid rgba(14,13,11,.1);}
.ab-lbl{font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--ink3);margin-bottom:14px;}
.ab-pills{display:flex;flex-wrap:wrap;}
.ab-pill{font-family:var(--serif);font-style:italic;font-size:15px;color:var(--ink2);}
.ab-pill+.ab-pill::before{content:'·';margin:0 8px;color:var(--ink3);}

/* IMPACT */
#impact-bg{background:var(--ink);}
#impact-bg .lbl::after{background:var(--gold);}
#impact-bg .sh{color:var(--cream);}
.impact-sub{color:rgba(248,245,240,.45);font-weight:300;font-size:15px;max-width:500px;margin-top:10px;margin-bottom:52px;}
.ig{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.06);}
.ic{padding:42px 34px;background:var(--ink);transition:background .2s;}
.ic:hover{background:#191714;}
.ic-n{font-family:var(--serif);font-size:50px;font-weight:700;letter-spacing:-.03em;color:var(--gold);line-height:1;margin-bottom:10px;}
.ic-n sup{font-size:25px;vertical-align:super;}
.ic-d{font-size:13px;color:rgba(248,245,240,.5);font-weight:300;line-height:1.6;}
.ic-b{font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:rgba(184,149,90,.55);margin-top:10px;}

/* RESULTS - BEFORE / AFTER */
.ba-grid{display:flex;flex-direction:column;gap:40px;margin-top:52px;}
.ba-row{border:1px solid rgba(14,13,11,.1);border-radius:6px;background:var(--cream);padding:30px;transition:box-shadow .25s,border-color .25s;}
.ba-row:hover{box-shadow:0 18px 50px -28px rgba(14,13,11,.28);border-color:rgba(184,149,90,.4);}
.ba-head{display:flex;align-items:center;justify-content:space-between;gap:20px;flex-wrap:wrap;margin-bottom:24px;}
.ba-acct{font-family:var(--serif);font-size:21px;font-weight:700;letter-spacing:-.01em;}
.ba-meta{font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--ink3);margin-top:5px;}
.ba-result{font-size:13px;font-weight:500;letter-spacing:.02em;color:#7a5c28;background:var(--gold-light);border:1px solid rgba(184,149,90,.35);border-radius:100px;padding:9px 18px;white-space:nowrap;}
.ba-result span{color:var(--ink3);font-weight:400;}
.ba-pair{display:grid;grid-template-columns:1fr auto 1fr;align-items:center;gap:18px;}
.ba-fig{position:relative;border-radius:5px;overflow:hidden;border:1px solid rgba(14,13,11,.12);background:var(--cream2);}
.ba-fig img{display:block;width:100%;aspect-ratio:2/3;object-fit:cover;object-position:top center;}
.ba-badge{position:absolute;top:12px;left:12px;z-index:2;font-size:10px;font-weight:600;letter-spacing:.12em;text-transform:uppercase;padding:6px 12px;border-radius:100px;backdrop-filter:blur(6px);}
.ba-badge.before{background:rgba(14,13,11,.78);color:var(--cream);}
.ba-badge.after{background:var(--gold);color:var(--ink);}
.ba-arrow{font-family:var(--serif);font-size:30px;color:var(--gold);line-height:1;}
/* placeholder slot - replace .ba-slot div with <img src="..."/> when screenshots are ready */
.ba-slot{aspect-ratio:9/16;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:10px;text-align:center;padding:20px;color:var(--ink3);font-size:12px;letter-spacing:.04em;line-height:1.5;background:repeating-linear-gradient(45deg,var(--cream2),var(--cream2) 10px,var(--cream3) 10px,var(--cream3) 20px);}
.ba-slot svg{width:30px;height:30px;stroke:var(--ink3);fill:none;stroke-width:1.4;}
.ba-slot code{font-family:ui-monospace,Menlo,monospace;font-size:11px;color:var(--gold);background:rgba(184,149,90,.1);padding:3px 7px;border-radius:4px;}
.ba-result.note{background:transparent;border:none;color:var(--ink2);font-weight:300;font-size:13px;padding:0;white-space:normal;}
/* RESULTS GALLERY - supporting proof screenshots */
.rg-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:26px;margin:24px auto 0;max-width:760px;}
.rg-card{display:flex;flex-direction:column;gap:14px;}
.rg-shot{position:relative;border-radius:6px;overflow:hidden;border:1px solid rgba(14,13,11,.12);background:var(--cream2);box-shadow:0 12px 36px -24px rgba(14,13,11,.4);}
.rg-shot img{display:block;width:100%;aspect-ratio:4/5;object-fit:cover;object-position:top center;}
.rg-cap{font-size:13px;color:var(--ink2);font-weight:300;line-height:1.5;}
.rg-cap strong{color:var(--ink);font-weight:600;font-family:var(--serif);}
.rg-tag{font-size:10px;letter-spacing:.12em;text-transform:uppercase;color:var(--gold);margin-bottom:4px;display:block;}

/* EXPERIENCE */
.exp-list{display:flex;flex-direction:column;margin-top:52px;}
.exp-item{display:grid;grid-template-columns:200px 1fr;gap:48px;padding:40px 0;border-top:1px solid rgba(14,13,11,.1);}
.exp-item:last-child{border-bottom:1px solid rgba(14,13,11,.1);}
.exp-date{font-size:12px;letter-spacing:.08em;text-transform:uppercase;color:var(--ink3);margin-bottom:10px;}
.exp-co{font-family:var(--serif);font-size:18px;font-weight:700;margin-bottom:8px;}
.exp-type{font-size:10px;letter-spacing:.1em;text-transform:uppercase;padding:4px 10px;border-radius:100px;background:var(--gold-light);color:#7a5c28;border:1px solid rgba(184,149,90,.3);}
.exp-role{font-family:var(--serif);font-size:22px;font-weight:700;letter-spacing:-.01em;margin-bottom:16px;}
.win{position:relative;padding-left:18px;font-size:14px;color:var(--ink2);font-weight:300;line-height:1.6;margin-bottom:10px;}
.win::before{content:'';position:absolute;left:0;top:10px;width:4px;height:4px;border-radius:50%;background:var(--gold);}
.win strong{color:var(--ink);font-weight:500;}

/* WORK */
#work-bg{background:var(--cream2);}
.work-top{display:flex;justify-content:space-between;align-items:flex-end;flex-wrap:wrap;gap:20px;}
.work-note{margin-top:8px;font-size:13px;color:var(--gold);}
.work-note a{color:inherit;text-decoration:none;border-bottom:1px solid rgba(184,149,90,.4);}
.work-note a:hover{border-color:var(--gold);}

/* Project cards */
.pg{display:grid;grid-template-columns:repeat(12,1fr);gap:16px;margin-top:52px;}
.pc{background:var(--cream);border-radius:2px;overflow:hidden;transition:transform .3s cubic-bezier(.25,.46,.45,.94);cursor:none;text-decoration:none;color:inherit;display:block;position:relative;}
.pc:hover{transform:translateY(-5px);}
.pc:hover .pc-arrow{transform:translate(3px,-3px);}
.ai-card{height:100%;width:100%;position:relative;overflow:hidden;transition:all .4s ease;}.ai-card::before{content:'';position:absolute;top:0;left:0;right:0;bottom:0;background:radial-gradient(circle at center,rgba(37,99,235,.05) 0%,transparent 70%);opacity:0;transition:opacity .4s ease;}.pc:hover .ai-card::before{opacity:1;}.pc:hover .ai-card{background-color:#0d0d0d !important;}
/* repeating 5-card pattern: rows of (7+5) then (4+4+4), always tiling 12 cols at any card count */
.pc{grid-column:span 4;}
.pc:nth-child(5n+1){grid-column:span 7;}
.pc:nth-child(5n+2){grid-column:span 5;}
.pc:nth-child(5n+3){grid-column:span 4;}
.pc:nth-child(5n+4){grid-column:span 4;}
.pc:nth-child(5n){grid-column:span 4;}
/* AI Projects grid: uniform 2-up so any count tiles cleanly */
#ai .pc{grid-column:span 6;}

.pt{aspect-ratio:16/9;position:relative;overflow:hidden;display:block;background:var(--cream2);}
.pt video{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;transition:opacity .5s;opacity:0;}
.pt-thumb{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;transition:opacity .4s;}
.pc:hover .pt-thumb{opacity:0;}
.pc:hover .pt video{opacity:1;}
.pt-ov{position:absolute;inset:0;background:rgba(14,13,11,0);transition:background .3s;display:flex;align-items:center;justify-content:center;z-index:3;}
.pc:hover .pt-ov{background:rgba(14,13,11,.45);}
.pt-ov span{color:var(--cream);font-size:12px;letter-spacing:.1em;text-transform:uppercase;font-weight:500;opacity:0;transition:opacity .3s;}
.pc:hover .pt-ov span{opacity:1;}
.pi{padding:18px 22px 22px;display:flex;justify-content:space-between;align-items:flex-end;}
.pn{font-size:15px;font-weight:500;letter-spacing:-.01em;margin-bottom:4px;}
.ptag{font-size:11px;color:var(--ink3);letter-spacing:.06em;text-transform:uppercase;}
.pc-arrow{font-size:16px;color:var(--ink3);transition:transform .2s;line-height:1;}

/* Showreel banner */
.showreel-wrap{margin-top:48px;position:relative;border-radius:2px;overflow:hidden;background:var(--ink);aspect-ratio:16/7;display:flex;align-items:center;justify-content:center;cursor:none;text-decoration:none;}
.showreel-play{width:72px;height:72px;border-radius:50%;border:2px solid rgba(248,245,240,.4);display:flex;align-items:center;justify-content:center;transition:all .3s;z-index:2;}
.showreel-wrap:hover .showreel-play{background:var(--gold);border-color:var(--gold);transform:scale(1.08);}
.showreel-play svg{width:22px;height:22px;fill:var(--cream);margin-left:3px;}
.showreel-label{position:absolute;bottom:28px;left:32px;font-size:12px;letter-spacing:.12em;text-transform:uppercase;color:rgba(248,245,240,.4);}
.showreel-label span{color:var(--gold);}
.showreel-count{position:absolute;top:28px;right:32px;font-size:12px;letter-spacing:.1em;text-transform:uppercase;color:rgba(248,245,240,.3);}

/* SKILLS */
.skills-cols{display:grid;grid-template-columns:repeat(2,1fr);gap:48px;margin-top:52px;}
.sg-t{font-family:var(--serif);font-size:20px;font-weight:700;margin-bottom:18px;padding-bottom:14px;border-bottom:1px solid rgba(14,13,11,.1);}
.stags{display:flex;flex-wrap:wrap;gap:8px;}
.stag{font-size:13px;font-weight:300;padding:8px 16px;border-radius:100px;background:var(--cream2);border:1px solid var(--cream3);color:var(--ink2);transition:all .2s;}
.stag:hover{background:var(--gold-light);color:#7a5c28;border-color:rgba(184,149,90,.3);}
.certs-block{background:var(--ink);padding:40px 48px;border-radius:2px;margin-top:48px;}
.cert-lbl{font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--gold);margin-bottom:24px;display:flex;align-items:center;gap:10px;}
.cert-lbl::after{content:'';width:24px;height:1px;background:var(--gold);}
.cert-item{display:flex;align-items:baseline;gap:14px;font-size:14px;color:rgba(248,245,240,.6);font-weight:300;margin-bottom:14px;}
.cert-item::before{content:'✦';font-size:8px;color:var(--gold);flex-shrink:0;}
.cert-item strong{color:var(--cream);font-weight:500;}
.edu-grid{display:grid;grid-template-columns:1fr 1fr;gap:20px;margin-top:40px;}
.edu-card{padding:32px 36px;background:var(--cream2);border-radius:2px;border-left:3px solid var(--gold);}
.edu-yr{font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--gold);margin-bottom:10px;}
.edu-deg{font-family:var(--serif);font-size:18px;font-weight:700;line-height:1.2;margin-bottom:8px;}
.edu-school{font-size:14px;color:var(--ink2);font-weight:300;}

/* REVIEWS */
#reviews-bg{background:var(--cream2);}
.reviews-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-top:52px;}
.rv-card{background:var(--cream);border-radius:2px;overflow:hidden;display:flex;flex-direction:column;}
.rv-video-wrap{position:relative;aspect-ratio:9/16;overflow:hidden;background:var(--ink);cursor:none;}
.rv-video-wrap video{width:100%;height:100%;object-fit:cover;display:block;}
.rv-thumb{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;transition:opacity .4s;}
.rv-play{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;z-index:3;transition:background .3s;}
.rv-play-btn{width:56px;height:56px;border-radius:50%;border:2px solid rgba(248,245,240,.5);display:flex;align-items:center;justify-content:center;transition:all .3s;background:rgba(14,13,11,.3);}
.rv-play-btn svg{width:18px;height:18px;fill:var(--cream);margin-left:3px;}
.rv-video-wrap:hover .rv-play-btn{background:var(--gold);border-color:var(--gold);transform:scale(1.08);}
.rv-video-wrap:hover .rv-thumb{opacity:0;}
.rv-video-wrap.playing .rv-play{opacity:0;}
.rv-video-wrap.playing video{opacity:1;}
.rv-body{padding:22px 24px 26px;}
.rv-stars{color:var(--gold);font-size:13px;letter-spacing:2px;margin-bottom:12px;}
.rv-quote{font-size:14px;font-weight:300;color:var(--ink2);line-height:1.8;font-style:italic;margin-bottom:16px;}
.rv-author{display:flex;align-items:center;gap:12px;}
.rv-avatar{width:38px;height:38px;border-radius:50%;object-fit:cover;background:var(--cream2);border:1px solid var(--cream3);}
.rv-name{font-size:13px;font-weight:500;color:var(--ink);line-height:1.2;}
.rv-title{font-size:11px;color:var(--ink3);letter-spacing:.04em;margin-top:2px;}

/* CONTACT */
#contact-bg{background:var(--ink);}
#contact-bg .lbl::after{background:var(--gold);}
#contact-bg .sh{color:var(--cream);}
.cg{display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:start;margin-top:52px;}
.cl p{color:rgba(248,245,240,.5);font-weight:300;line-height:1.8;font-size:15px;margin-bottom:36px;}
.c-links{display:flex;flex-direction:column;}
.c-lnk{display:flex;align-items:baseline;gap:16px;text-decoration:none;padding:14px 0;border-bottom:1px solid rgba(255,255,255,.07);transition:border-color .2s;}
.c-lnk:hover{border-color:rgba(184,149,90,.4);}
.c-lnk:hover .c-val{color:var(--gold);}
.c-key{font-size:10px;letter-spacing:.12em;text-transform:uppercase;color:rgba(248,245,240,.3);min-width:80px;}
.c-val{font-size:14px;color:rgba(248,245,240,.7);font-weight:300;transition:color .2s;}
.cf{display:flex;flex-direction:column;gap:20px;}
.frow{display:grid;grid-template-columns:1fr 1fr;gap:16px;}
.fg{display:flex;flex-direction:column;gap:8px;}
.fg label{font-size:10px;letter-spacing:.12em;text-transform:uppercase;color:rgba(248,245,240,.3);}
.fg input,.fg textarea,.fg select{font-family:var(--sans);font-size:14px;font-weight:300;color:var(--cream);background:transparent;border:none;border-bottom:1px solid rgba(255,255,255,.12);padding:12px 0;outline:none;resize:none;transition:border-color .2s;-webkit-appearance:none;}
.fg select option{background:var(--ink);}
.fg input:focus,.fg textarea:focus,.fg select:focus{border-bottom-color:var(--gold);}
.fg input::placeholder,.fg textarea::placeholder{color:rgba(248,245,240,.22);}
.fg textarea{min-height:110px;}
#fsuccess{display:none;font-size:13px;color:var(--gold);margin-top:8px;}

footer{border-top:1px solid rgba(14,13,11,.1);padding:28px 52px;display:flex;justify-content:space-between;align-items:center;font-size:12px;color:var(--ink3);background:var(--cream);}
footer a{color:var(--ink3);text-decoration:none;}
footer a:hover{color:var(--gold);}
.fl{display:flex;gap:24px;}

@keyframes fadeUp{from{opacity:0;transform:translateY(22px);}to{opacity:1;transform:none;}}
.r{opacity:0;transform:translateY(26px);transition:opacity .75s cubic-bezier(.25,.46,.45,.94),transform .75s cubic-bezier(.25,.46,.45,.94);}
.r.in{opacity:1;transform:none;}

@media(max-width:900px){
  nav{padding:0 24px;}.nav-links,.nav-cta{display:none;}
  .sw{padding:80px 24px;}#hero{padding:calc(var(--nav)+40px) 24px 60px;}
  .hero-bg-text{display:none;}.hero-stats{gap:24px;flex-wrap:wrap;}
  .about-grid,.cg{grid-template-columns:1fr;gap:48px;}
  .ig{grid-template-columns:1fr 1fr;}
  .exp-item{grid-template-columns:1fr;gap:12px;}
  .ba-row{padding:20px;}.ba-pair{grid-template-columns:1fr;gap:14px;}.ba-arrow{transform:rotate(90deg);justify-self:center;}
  .ba-result{white-space:normal;}
  .rg-grid{grid-template-columns:1fr;gap:32px;}
  .pg{grid-template-columns:1fr;}.pc:nth-child(n){grid-column:span 1;}
  .skills-cols,.edu-grid{grid-template-columns:1fr;}
  .reviews-grid{grid-template-columns:1fr;}
  .frow{grid-template-columns:1fr;}
  footer{flex-direction:column;gap:12px;text-align:center;}
  .certs-block{padding:28px 24px;}
  body{cursor:auto;}.cursor,.cursor-ring{display:none;}
}

/* ---- content sub-pages (services / case studies / faq / hire) ---- */
.page-hero{padding:calc(var(--nav) + 80px) 52px 36px;max-width:var(--max);margin:0 auto;}
.page-lead{font-size:clamp(16px,2vw,20px);color:var(--ink2);font-weight:300;max-width:700px;margin-top:18px;line-height:1.7;}
.cards{display:grid;grid-template-columns:repeat(2,1fr);gap:24px;margin-top:8px;}
.card{background:var(--cream);border:1px solid rgba(14,13,11,.1);border-radius:6px;padding:34px;transition:box-shadow .25s,border-color .25s,transform .25s;}
.card:hover{box-shadow:0 18px 50px -28px rgba(14,13,11,.25);border-color:rgba(184,149,90,.4);transform:translateY(-3px);}
.card .tag{font-size:10px;letter-spacing:.12em;text-transform:uppercase;color:var(--gold);margin-bottom:14px;display:block;}
.card h3{font-family:var(--serif);font-size:22px;margin-bottom:10px;line-height:1.2;}
.card p{color:var(--ink2);font-weight:300;font-size:14.5px;line-height:1.65;}
.card .metric{margin-top:16px;font-family:var(--serif);font-size:15px;color:#7a5c28;}
.prose{max-width:760px;}
.prose p{color:var(--ink2);font-weight:300;font-size:15.5px;line-height:1.8;margin-bottom:16px;}
.prose strong{color:var(--ink);font-weight:600;}
.faq-item{border-top:1px solid rgba(14,13,11,.1);padding:26px 0;max-width:840px;}
.faq-item:last-child{border-bottom:1px solid rgba(14,13,11,.1);}
.faq-q{font-family:var(--serif);font-size:19px;margin-bottom:10px;line-height:1.3;}
.faq-a{color:var(--ink2);font-weight:300;font-size:15px;line-height:1.75;}
.faq-a a{color:#7a5c28;}
.cta-band{background:var(--ink);color:var(--cream);padding:64px 52px;text-align:center;margin-top:80px;}
.cta-band h2{font-family:var(--serif);font-size:clamp(28px,4vw,40px);margin-bottom:14px;color:var(--cream);}
.cta-band p{color:rgba(248,245,240,.6);font-weight:300;margin-bottom:28px;max-width:560px;margin-left:auto;margin-right:auto;}
.crumb{font-size:12px;color:var(--ink3);margin-bottom:22px;letter-spacing:.02em;}
.crumb a{color:var(--ink3);text-decoration:none;}
.crumb a:hover{color:var(--gold);}
@media(max-width:900px){
  .page-hero{padding:calc(var(--nav) + 50px) 24px 28px;}
  .cards{grid-template-columns:1fr;}
  .cta-band{padding:48px 24px;}
}
