/* ============================================================
   NHI VO — PORTFOLIO WEBSITE
   To edit: open in VS Code, use Ctrl+F to find text to change
   To add a new project: copy a .project-case block and update
   ============================================================ */
:root{
  --bg:#0B0B0A;
  --surface:#141413;
  --surface-2:#191816;
  --border:rgba(245,240,232,0.09);
  --cream:#F7F0E6;
  --muted:rgba(247,240,230,0.62);
  --subtle:rgba(247,240,230,0.22);
  --gold:#C7A66A;
  --gold2:#E3C688;
  --serif:'Newsreader',Georgia,serif;
  --sans:'Inter',Arial,sans-serif;
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth;scroll-padding-top:80px}
body{background:var(--bg);color:var(--cream);font-family:var(--sans);font-size:15px;line-height:1.7;overflow-x:hidden;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased}
a{text-decoration:none}
img{display:block;width:100%;height:100%;object-fit:cover}


/* Nav */
nav{position:fixed;top:0;left:0;right:0;z-index:100;padding:1.35rem clamp(1.25rem,4vw,4rem);display:flex;justify-content:space-between;align-items:center;transition:all .3s}
nav.on{background:rgba(11,11,10,.94);border-bottom:1px solid var(--border);backdrop-filter:blur(14px)}
.logo{font-family:var(--serif);font-size:22px;font-weight:400;color:var(--cream);letter-spacing:.2px}
.nav-links{display:flex;gap:clamp(1.25rem,3vw,2.5rem);list-style:none}
.nav-links a{font-size:10px;font-weight:600;letter-spacing:2px;text-transform:uppercase;color:var(--muted);transition:color .2s}
.nav-links a:hover,.nav-links a.active{color:var(--cream)}

/* Hero — split layout */
.hero{min-height:100vh;display:grid;grid-template-columns:minmax(0,1fr) minmax(360px,34vw)}
.hero-left{display:flex;flex-direction:column;justify-content:center;padding:8rem clamp(1.5rem,5vw,5.5rem) 4rem;overflow:hidden}
.hero-right{background:#000;position:relative;overflow:hidden}
.hero-right img{width:100%;height:100%;object-fit:contain;object-position:center bottom;position:relative;z-index:1;filter:saturate(1.02) contrast(1.02)}
.to-top{position:fixed;right:clamp(1rem,2vw,1.6rem);bottom:clamp(1rem,2vw,1.6rem);z-index:260;width:42px;height:42px;border:1px solid rgba(199,166,106,.45);background:rgba(11,11,10,.78);color:var(--cream);display:grid;place-items:center;font-size:18px;line-height:1;text-decoration:none;opacity:0;pointer-events:none;transform:translateY(10px);transition:opacity .25s ease,transform .25s ease,border-color .2s ease,background .2s ease;backdrop-filter:blur(10px)}
.to-top.show{opacity:1;pointer-events:auto;transform:none}
.to-top:hover{border-color:var(--gold);background:rgba(199,166,106,.16);color:var(--gold)}
.doodle{position:absolute;width:clamp(40px,5vw,74px);height:auto;fill:none;stroke:rgba(16,38,59,.72);stroke-width:1.7;stroke-linecap:round;stroke-linejoin:round;filter:drop-shadow(0 12px 18px rgba(16,38,59,.12));animation:floatDoodle 5.8s ease-in-out infinite}
.doodle .trace{stroke-dasharray:78;stroke-dashoffset:78;animation:drawTrace 4.2s ease-in-out infinite}
.doodle.monitor{left:10%;top:16%;animation-delay:.1s}
.doodle.pen{right:13%;top:18%;width:clamp(34px,4.4vw,62px);stroke:rgba(199,166,106,.9);animation-delay:.7s}
.doodle.mouse{right:10%;bottom:22%;width:clamp(34px,4vw,58px);animation-delay:1.15s}
.doodle.lines{left:11%;bottom:24%;width:clamp(44px,5.5vw,82px);stroke:rgba(16,38,59,.48);animation-delay:1.7s}
.spark{position:absolute;width:7px;height:7px;border:1px solid rgba(199,166,106,.82);transform:rotate(45deg);animation:sparkleBlink 2.8s ease-in-out infinite}
.spark.s1{left:23%;top:30%}
.spark.s2{right:25%;top:34%;animation-delay:.7s}
.spark.s3{left:27%;bottom:20%;animation-delay:1.35s}

.eyebrow{font-size:10px;font-weight:600;letter-spacing:2.4px;text-transform:uppercase;color:var(--gold);margin-bottom:1.5rem;opacity:0;animation:up .9s ease forwards}
.hero-name{font-family:var(--serif);font-size:clamp(68px,9vw,138px);font-weight:300;line-height:.9;letter-spacing:-1px;margin-bottom:2rem;opacity:0;animation:up .9s ease .1s forwards}
.hero-name em{font-style:italic;color:var(--gold)}
.hero-sub{font-size:clamp(14px,1.25vw,16px);color:var(--muted);max-width:430px;line-height:1.9;margin-bottom:2.5rem;opacity:0;animation:up .9s ease .2s forwards}
.cta-row{display:flex;gap:1rem;flex-wrap:wrap;opacity:0;animation:up .9s ease .3s forwards}
.btn-p{padding:.9rem 1.8rem;background:var(--gold);color:var(--bg);font-family:var(--sans);font-size:10px;font-weight:700;letter-spacing:2px;text-transform:uppercase;border:1px solid var(--gold);cursor:pointer;transition:background .2s,border-color .2s,transform .2s;display:inline-flex;align-items:center;justify-content:center;min-height:44px}
.btn-p:hover{background:var(--gold2);border-color:var(--gold2);transform:translateY(-1px)}
.btn-o{padding:.9rem 1.8rem;background:transparent;color:var(--muted);font-family:var(--sans);font-size:10px;font-weight:600;letter-spacing:2px;text-transform:uppercase;border:1px solid var(--border);cursor:pointer;transition:all .2s;display:inline-flex;align-items:center;justify-content:center;min-height:44px}
.btn-o:hover{border-color:var(--subtle);color:var(--cream)}
.hero-sc{font-size:9px;letter-spacing:2.5px;text-transform:uppercase;color:var(--subtle);display:flex;align-items:center;gap:.75rem;margin-top:auto;padding-top:3rem;opacity:0;animation:up .9s ease .5s forwards}
.hero-sc::before{content:'';width:36px;height:1px;background:var(--subtle)}

/* Section base */
section{padding:clamp(4.5rem,8vw,7rem) clamp(1.5rem,5vw,5.5rem)}
.sec-label{font-size:9px;font-weight:600;letter-spacing:2.6px;text-transform:uppercase;color:var(--gold);margin-bottom:clamp(2rem,4vw,3.25rem);display:flex;align-items:center;gap:1rem}
.sec-label::after{content:'';height:1px;width:36px;background:var(--gold);opacity:.4}

/* About */
.about{border-top:1px solid var(--border)}
.ag{display:grid;grid-template-columns:minmax(280px,.9fr) minmax(0,1fr);gap:clamp(3rem,7vw,7rem);align-items:start}
.ah{font-family:var(--serif);font-size:clamp(42px,5vw,70px);font-weight:300;line-height:1.08;letter-spacing:-.2px;max-width:620px}
.ah em{font-style:italic;color:var(--gold)}
.ab{font-size:14.5px;color:var(--muted);line-height:1.95;margin-bottom:1.15rem;max-width:650px}
.stats{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem;margin-top:3rem;padding-top:2.5rem;border-top:1px solid var(--border)}
.sn{font-family:var(--serif);font-size:clamp(38px,4vw,50px);font-weight:300;line-height:1}
.sl{font-size:9px;letter-spacing:1.7px;text-transform:uppercase;color:var(--muted);margin-top:.45rem;line-height:1.45}

/* ============================================================
   WORK / PROJECTS — Editorial asymmetric grid
   ============================================================ */
.work{border-top:1px solid var(--border);padding:clamp(4.5rem,7vw,6rem) 0 0}.work>.sec-label{padding:0 clamp(1.5rem,5vw,5.5rem);margin-bottom:clamp(2rem,4vw,3rem)}

/* Asymmetric 2-col grid */
.work-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:0;border-top:1px solid var(--border);border-left:1px solid var(--border)}
/* all cards equal */
.wcard-wrap{cursor:pointer;border-right:1px solid var(--border);border-bottom:1px solid var(--border)}


/* Image frame */
.wcard{position:relative;overflow:hidden;aspect-ratio:1/1}
.wcard.is-landscape{aspect-ratio:1/1}
.wcard.is-portrait{aspect-ratio:1/1}

/* Corner registration marks */
.cn{position:absolute;width:13px;height:13px;z-index:5;opacity:0;transition:opacity .45s ease}
.wcard-wrap:hover .cn{opacity:1}
.cn.tl{top:13px;left:13px;border-top:1px solid var(--gold);border-left:1px solid var(--gold)}
.cn.tr{top:13px;right:13px;border-top:1px solid var(--gold);border-right:1px solid var(--gold)}
.cn.bl{bottom:13px;left:13px;border-bottom:1px solid var(--gold);border-left:1px solid var(--gold)}
.cn.br{bottom:13px;right:13px;border-bottom:1px solid var(--gold);border-right:1px solid var(--gold)}

/* Image */
.wcard-img{position:absolute;inset:0}
.wcard-img img{width:100%;height:100%;object-fit:cover;transition:transform 1s cubic-bezier(.25,.46,.45,.94);filter:contrast(1.04) saturate(1.06)}
.wcard-wrap:hover .wcard-img img{transform:scale(1.055)}
.wcard-wrap[data-project="sip"] .wcard-img{background:#111}
.wcard-wrap[data-project="sip"] .wcard-img img{object-fit:cover;padding:0;filter:brightness(1.02) contrast(1.04) saturate(1.04);mix-blend-mode:normal}
.wcard-wrap[data-project="thesip"] .wcard-img{background:#1C3A0F}
.wcard-wrap[data-project="thesip"] .wcard-img img{object-position:center 42%;filter:brightness(.9) contrast(1.08) saturate(1.02)}
.wcard-wrap[data-project="thesis"] .wcard-img{display:flex;align-items:center;justify-content:center;background:radial-gradient(circle at 50% 32%,rgba(227,198,136,.16),transparent 34%),linear-gradient(145deg,#111b22,#071016)}
.wcard-wrap[data-project="thesis"] .wcard-img img{width:70%;height:86%;object-fit:contain;background:#fff;box-shadow:0 28px 70px rgba(0,0,0,.45);filter:contrast(1.02) saturate(1.04)}
.wcard-wrap[data-project="thesis"]:hover .wcard-img img{transform:translateY(-4px) rotate(-1.5deg) scale(1.025)}
.web-card{background:#0f1722}
.web-thumb{position:absolute;inset:0;padding:clamp(1rem,2.2vw,2rem);background:radial-gradient(circle at 72% 24%,rgba(227,198,136,.24),transparent 26%),linear-gradient(145deg,#111827 0%,#1b2432 50%,#080b10 100%);overflow:hidden}
.web-thumb::before{content:'';position:absolute;inset:-15%;background:repeating-radial-gradient(ellipse at 66% 42%,transparent 0 18px,rgba(227,198,136,.18) 19px 21px,transparent 22px 34px);transform:rotate(-16deg);opacity:.65}
.web-browser{position:relative;z-index:1;height:100%;border:1px solid rgba(247,240,230,.16);background:rgba(7,10,15,.74);box-shadow:0 24px 70px rgba(0,0,0,.34);display:flex;flex-direction:column}
.web-top{height:34px;border-bottom:1px solid rgba(247,240,230,.12);display:flex;align-items:center;gap:7px;padding:0 13px}
.web-dot{width:7px;height:7px;border-radius:50%;background:var(--gold)}
.web-dot:nth-child(2){opacity:.6}.web-dot:nth-child(3){opacity:.34}
.web-screen{position:relative;flex:1;overflow:hidden;padding:clamp(1rem,2.3vw,1.8rem)}
.web-screen::before{content:'';position:absolute;right:-20%;top:8%;width:70%;aspect-ratio:1;border-radius:50%;background:radial-gradient(circle,rgba(57,101,165,.45),transparent 58%);filter:blur(2px)}
.web-kicker{position:relative;font-size:8px;font-weight:700;letter-spacing:2px;text-transform:uppercase;color:var(--gold);margin-bottom:1.2rem}
.web-title{position:relative;font-family:var(--serif);font-size:clamp(34px,4.6vw,60px);font-weight:300;line-height:.88;color:var(--cream)}
.web-title em{display:block;color:#f1c64e;font-style:italic}
.web-lines{position:absolute;left:clamp(1rem,2.3vw,1.8rem);right:clamp(1rem,2.3vw,1.8rem);bottom:clamp(1rem,2.3vw,1.8rem);display:grid;gap:8px}
.web-line{height:7px;background:rgba(247,240,230,.15)}
.web-line:nth-child(1){width:76%}.web-line:nth-child(2){width:54%}.web-line:nth-child(3){width:32%;background:rgba(227,198,136,.5)}
.web-swirl{position:absolute;right:12%;bottom:18%;width:32%;height:24%;border:1px solid rgba(227,198,136,.45);border-left-color:transparent;border-radius:50%;transform:rotate(-22deg)}
.live-thumb{position:absolute;inset:0;background:#0d1118;overflow:hidden}
.live-thumb iframe{width:144%;height:144%;border:0;transform:scale(.7);transform-origin:top left;pointer-events:none;background:#fff}
.live-thumb img{width:100%;height:100%;object-fit:contain;padding:7%;background:linear-gradient(145deg,#111,#2b2b2b);filter:contrast(1.03) saturate(1.03);transition:transform .8s cubic-bezier(.25,.46,.45,.94)}
.wcard-wrap:hover .live-thumb img{transform:scale(1.025)}

/* Gradient overlay */
.wcard-overlay{position:absolute;inset:0;background:linear-gradient(to top,rgba(11,11,10,.9) 0%,rgba(11,11,10,.18) 58%,transparent 100%);display:flex;flex-direction:column;justify-content:flex-end;padding:clamp(1.35rem,2.4vw,2.25rem);opacity:0;transition:opacity .38s ease}
.wcard-wrap:hover .wcard-overlay{opacity:1}
.wcard-cat-ov{font-size:9px;letter-spacing:2.5px;text-transform:uppercase;color:var(--gold);margin-bottom:.55rem;opacity:1}
.wcard-name-ov{font-family:var(--serif);font-size:clamp(20px,2.2vw,32px);font-weight:300;line-height:1.05;color:#fff}
.wcard-name-ov em{font-style:italic;color:var(--gold)}

/* Footer strip below image */
.wcard-footer{min-height:90px;padding:1rem 1.25rem .95rem;display:flex;align-items:center;gap:1rem;border-top:none;transition:border-color .35s ease;margin-top:0}
.wcard-wrap:hover .wcard-footer{border-color:rgba(200,169,110,.28)}
.wf-num{font-family:var(--serif);font-size:11px;color:var(--gold);opacity:.5;min-width:18px;letter-spacing:.5px}
.wf-title{font-family:var(--serif);font-size:18px;font-weight:300;line-height:1.1;color:var(--cream)}
.wf-title em{font-style:italic;color:var(--gold)}
.wf-cat{font-size:9px;letter-spacing:2px;text-transform:uppercase;color:var(--muted);margin-top:4px}
.wf-arrow{margin-left:auto;width:13px;height:13px;stroke:var(--gold);fill:none;stroke-width:1.5;opacity:0;transform:translate(-5px,5px);transition:all .35s ease;flex-shrink:0}
.wcard-wrap:hover .wf-arrow{opacity:1;transform:none}

/* ── Modal ─────────────────────────────────────────── */
.modal-bg{position:fixed;inset:0;z-index:300;background:rgba(11,11,10,.97);opacity:0;pointer-events:none;transition:opacity .35s ease;overflow-y:auto;overscroll-behavior:contain}
.modal-bg.open{opacity:1;pointer-events:all}

.modal-inner{max-width:1240px;margin:0 auto;padding:5.5rem clamp(1.5rem,5vw,4rem) 7rem;transform:translateY(28px);transition:transform .45s cubic-bezier(.25,.46,.45,.94)}
.modal-bg.open .modal-inner{transform:none}

.modal-close{position:fixed;top:1.75rem;right:2.5rem;z-index:10;background:none;border:1px solid var(--border);color:var(--muted);font-family:var(--sans);font-size:9px;font-weight:500;letter-spacing:2.5px;text-transform:uppercase;padding:.55rem 1.2rem;cursor:pointer;transition:all .2s}
.modal-close:hover{border-color:var(--subtle);color:var(--cream)}

.modal-header{display:flex;justify-content:space-between;align-items:flex-end;padding-bottom:2.5rem;border-bottom:1px solid var(--border);margin-bottom:2rem}
.modal-num{font-family:var(--serif);font-size:11px;color:var(--gold);opacity:.6;letter-spacing:1px;margin-bottom:.75rem}
.modal-title{font-family:var(--serif);font-size:clamp(44px,6vw,86px);font-weight:300;line-height:.95;letter-spacing:-1px}
.modal-title em{font-style:italic;color:var(--gold)}
.modal-meta{text-align:right}
.modal-cat{font-size:9px;letter-spacing:2.5px;text-transform:uppercase;color:var(--gold);margin-bottom:5px}
.modal-year{font-size:11px;color:var(--subtle)}

.modal-desc{max-width:720px;font-size:14.5px;color:var(--muted);line-height:1.95;margin-bottom:3rem}
.project-details{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--border);margin:-1rem 0 3rem}
.pd{background:var(--surface);padding:1.35rem 1.4rem}
.pd-label{font-size:9px;letter-spacing:2px;text-transform:uppercase;color:var(--gold);margin-bottom:.45rem}
.pd-text{font-size:12.5px;line-height:1.7;color:var(--muted)}

/* Modal image layout */
.modal-hero{width:100%;aspect-ratio:16/9;overflow:hidden;margin-bottom:3px}
.modal-hero img{width:100%;height:100%;object-fit:cover}
.modal-grid-2{display:grid;grid-template-columns:1fr 1fr;gap:3px;margin-bottom:3px}
.modal-grid-2 .img-wrap{overflow:hidden;aspect-ratio:4/3}
.modal-grid-2 .img-wrap img{width:100%;height:100%;object-fit:cover;transition:transform .7s ease}
.modal-grid-2 .img-wrap:hover img{transform:scale(1.03)}
.modal-grid-3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:3px}
.modal-grid-3 .img-wrap{overflow:hidden;aspect-ratio:4/3}
.modal-grid-3 .img-wrap img{width:100%;height:100%;object-fit:cover;transition:transform .7s ease}
.modal-grid-3 .img-wrap:hover img{transform:scale(1.04)}
.pop-gallery{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px;margin-top:3px;margin-bottom:3px}
.pop-gallery .img-wrap{aspect-ratio:4/3;overflow:hidden;background:#0b0b0a}
.pop-gallery img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .7s ease}
.pop-gallery .img-wrap:hover img{transform:scale(1.03)}
.pop-caption{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:.6rem}
.modal-caption{padding:1rem 0;font-size:10px;letter-spacing:1.5px;text-transform:uppercase;color:var(--subtle);border-bottom:1px solid var(--border);display:flex;justify-content:space-between;margin-bottom:3px}
.modal-caption a{color:var(--gold);transition:color .2s}
.modal-caption a:hover{color:var(--gold2)}
/* Asymmetric modal image row */
.modal-grid-asym{display:grid;grid-template-columns:1fr 2fr;gap:3px;margin-bottom:3px}
.modal-grid-asym .img-portrait{overflow:hidden;aspect-ratio:3/4}
.modal-grid-asym .img-landscape{overflow:hidden;aspect-ratio:3/2}
.modal-grid-asym img{width:100%;height:100%;object-fit:cover;transition:transform .7s ease}
.modal-grid-asym div:hover img{transform:scale(1.03)}

/* SIP extras */
.sip-concept{padding:1.75rem 2rem;border:1px solid var(--border);background:var(--surface);margin-bottom:2.5rem}
.sip-concept-tag{font-size:9px;letter-spacing:3px;text-transform:uppercase;color:var(--gold);margin-bottom:.75rem}
.sip-concept-line{font-family:var(--serif);font-size:clamp(22px,2.8vw,36px);font-weight:300;font-style:italic;color:var(--cream)}
.sip-variants{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--border);margin-bottom:3rem}
.sv{padding:1.5rem;display:flex;flex-direction:column;gap:.4rem;transition:background .2s}
.sv:hover{background:rgba(200,169,110,.04)}
.sv-dot{width:10px;height:10px;border-radius:50%;margin-bottom:.6rem}
.sv-name{font-family:var(--serif);font-size:17px;font-weight:300}
.sv-bean{font-size:9px;letter-spacing:1.5px;text-transform:uppercase;color:var(--subtle);margin-top:2px}
.sv-notes{font-size:11px;color:var(--muted);margin-top:.5rem;line-height:1.7}
.sip-print-img{width:100%;margin-bottom:3px;overflow:hidden}
.sip-print-img img{width:100%;display:block}
.studio-shot{background:#111;padding:0}
.studio-shot img{filter:brightness(1.02) contrast(1.04) saturate(1.04);object-fit:cover !important;background:#111;box-shadow:none}

/* Web design case */
.live-site-case{border:1px solid var(--border);background:var(--surface);padding:clamp(.75rem,1.5vw,1rem);margin-bottom:3px}
.live-site-frame{width:100%;height:clamp(520px,72vw,820px);border:0;background:#fff;display:block}

/* Thesis flipbook */
.flipbook-wrap{margin-top:1rem;border:1px solid var(--border);background:linear-gradient(145deg,rgba(20,20,18,.96),rgba(11,11,10,.98));padding:clamp(1rem,2.4vw,2rem)}
.flipbook-toolbar{display:flex;align-items:center;justify-content:space-between;gap:1rem;margin-bottom:1rem}
.flipbook-count{font-size:9px;letter-spacing:2.3px;text-transform:uppercase;color:var(--subtle)}
.flipbook-count strong{font-weight:600;color:var(--gold);margin-right:.4rem}
.flipbook-nav{display:flex;gap:.55rem}
.flip-btn{border:1px solid var(--border);background:transparent;color:var(--cream);font-family:var(--sans);font-size:9px;font-weight:600;letter-spacing:2px;text-transform:uppercase;padding:.7rem 1rem;cursor:pointer;transition:all .22s ease}
.flip-btn:hover:not(:disabled){border-color:rgba(200,169,110,.55);color:var(--gold);transform:translateY(-1px)}
.flip-btn:disabled{opacity:.3}
.flipbook-stage{perspective:1800px;background:radial-gradient(circle at 50% 30%,rgba(255,255,255,.07),transparent 42%),#0a0a09;padding:clamp(1rem,3vw,2.5rem);overflow:hidden}
.flipbook-spread{position:relative;display:grid;grid-template-columns:1fr 1fr;gap:clamp(.8rem,2vw,1.6rem);max-width:1050px;margin:0 auto}
.flipbook-spread::before{content:'';position:absolute;top:2%;bottom:2%;left:50%;width:1px;background:linear-gradient(to bottom,transparent,rgba(247,240,230,.26),transparent);z-index:2}
.flip-page{position:relative;aspect-ratio:1700/2200;background:#fff;overflow:hidden;box-shadow:0 30px 90px rgba(0,0,0,.44);transform-style:preserve-3d}
.flip-page img{display:block;width:100%;height:100%;object-fit:contain;background:#fff}
.flip-page.empty{background:linear-gradient(135deg,#f7f4ee,#d9d1c2)}
.flip-page.turning-next{animation:pageTurnNext .5s cubic-bezier(.2,.8,.2,1)}
.flip-page.turning-prev{animation:pageTurnPrev .5s cubic-bezier(.2,.8,.2,1)}
.thesis-caption{border-bottom:0;margin-bottom:0}

/* Brand identity section inside modal */
.brand-section{margin-top:4rem;padding-top:3rem;border-top:1px solid var(--border)}
.brand-label{font-size:9px;letter-spacing:3px;text-transform:uppercase;color:var(--gold);margin-bottom:2.5rem;display:flex;align-items:center;gap:1rem}
.brand-label::after{content:'';height:1px;width:36px;background:var(--gold);opacity:.4}
.brand-grid{display:grid;grid-template-columns:1fr 1fr;gap:3rem;align-items:start}
.brand-sub{font-size:9px;letter-spacing:2.5px;text-transform:uppercase;color:var(--subtle);margin-bottom:1.25rem}

/* Color palette */
.palette{display:flex;gap:3px}
.swatch{flex:1;height:80px;position:relative}
.swatch-label{position:absolute;bottom:-1.6rem;left:0;font-size:9px;letter-spacing:.5px;color:var(--subtle);white-space:nowrap}
.palette-wrap{padding-bottom:2.5rem}

/* Typography display */
.type-display{font-family:var(--serif);font-size:clamp(28px,3vw,42px);font-weight:300;font-style:italic;line-height:1.1;color:var(--cream);margin-bottom:.35rem}
.type-name{font-size:10px;letter-spacing:1.5px;text-transform:uppercase;color:var(--subtle);margin-bottom:1.75rem}
.type-body-demo{font-family:var(--sans);font-size:12px;color:var(--muted);line-height:1.9;letter-spacing:.3px;margin-bottom:.35rem}

/* Brand values */
.brand-values{display:flex;flex-wrap:wrap;gap:.5rem;margin-top:1rem}
.bv{font-size:9px;letter-spacing:2px;text-transform:uppercase;color:var(--muted);border:1px solid var(--border);padding:5px 14px;transition:all .2s}
.bv:hover{border-color:rgba(200,169,110,.4);color:var(--gold)}

/* ── Genero modal extras ─────────────────────────────── */
/* Research bar */
.proj-research{margin-bottom:2.5rem;padding:1.75rem 2rem;border:1px solid var(--border);background:var(--surface)}
.res-label{font-size:9px;letter-spacing:3px;text-transform:uppercase;color:var(--gold);margin-bottom:1.25rem}
.res-row{display:flex;align-items:center;gap:1.5rem;flex-wrap:wrap}
.res-item{display:flex;flex-direction:column;gap:4px}
.res-brand{font-family:var(--serif);font-size:22px;font-weight:300;font-style:italic}
.res-note{font-size:9px;letter-spacing:1.5px;text-transform:uppercase;color:var(--subtle)}
.res-op{font-family:var(--serif);font-size:28px;color:var(--gold);opacity:.35;line-height:1}
.res-arrow{font-size:14px;color:var(--gold);opacity:.5;letter-spacing:1px}

/* Scent notes */
.proj-scent{display:flex;align-items:baseline;gap:.9rem;flex-wrap:wrap;padding:1.75rem 0;border-top:1px solid var(--border);border-bottom:1px solid var(--border);margin-bottom:3rem}
.scent-hero{font-family:var(--serif);font-size:clamp(26px,3vw,38px);font-weight:300;font-style:italic;color:var(--cream)}
.scent-sep{color:var(--gold);opacity:.35;font-size:16px}
.scent-note{font-size:10px;letter-spacing:2.5px;text-transform:uppercase;color:var(--muted)}

/* Product lineup */
.proj-products{display:grid;grid-template-columns:repeat(3,1fr);margin-bottom:3rem;background:var(--border);gap:1px}
.pp{background:var(--bg);padding:1.75rem 1.5rem;display:flex;flex-direction:column;gap:.3rem;transition:background .2s}
.pp:hover{background:var(--surface)}
.pp-num{font-family:var(--serif);font-size:11px;color:var(--gold);opacity:.45;margin-bottom:.3rem}
.pp-name{font-size:12px;font-weight:500;letter-spacing:.2px;color:var(--cream)}
.pp-detail{font-size:9px;letter-spacing:1.5px;text-transform:uppercase;color:var(--subtle);margin-top:6px}

/* Genero color palette row */
.proj-palette{display:flex;gap:3px;margin-bottom:3rem;height:56px}
.gp-sw{flex:1;position:relative;overflow:hidden}
.gp-sw:hover .gp-name{opacity:1}
.gp-name{position:absolute;bottom:0;left:0;right:0;padding:5px 8px;font-size:8px;letter-spacing:1px;text-transform:uppercase;background:rgba(0,0,0,.4);opacity:0;transition:opacity .2s;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}

/* Skills */
.skills{border-top:1px solid var(--border);background:var(--surface)}
.sg{display:grid;grid-template-columns:repeat(4,1fr)}
.sk{padding:1.65rem 1.4rem;border-bottom:1px solid var(--border);border-right:1px solid var(--border);display:flex;align-items:center;gap:.9rem;transition:background .2s}
.sk:hover{background:rgba(200,169,110,.03)}
.snum{font-family:var(--serif);font-size:11px;color:var(--gold);opacity:.55;min-width:22px}
.sname{font-size:12.5px;font-weight:500;letter-spacing:.1px}
.tools-wrap{margin-top:3rem;padding-top:3rem;border-top:1px solid var(--border)}
.tl{font-size:9px;letter-spacing:3px;text-transform:uppercase;color:var(--subtle);margin-bottom:1.25rem}
.tr{display:flex;gap:.6rem;flex-wrap:wrap}
.tp{font-size:10px;letter-spacing:1px;color:var(--muted);border:1px solid var(--border);padding:5px 13px;transition:all .2s}
.tp:hover{border-color:rgba(200,169,110,.4);color:var(--gold)}

/* Experience */
.experience{border-top:1px solid var(--border)}
.ei{display:grid;grid-template-columns:minmax(160px,220px) 1fr;gap:clamp(1.5rem,4vw,4rem);padding:3rem 0;border-bottom:1px solid var(--border)}
.edate{font-size:11px;color:var(--subtle);padding-top:6px}
.eco{font-family:var(--serif);font-size:30px;font-weight:400;margin-bottom:4px;line-height:1.15}
.erole{font-size:9px;letter-spacing:2.5px;text-transform:uppercase;color:var(--gold);margin-bottom:1.25rem}
.ebl{list-style:none;display:flex;flex-direction:column;gap:.7rem}
.ebl li{font-size:13.5px;color:var(--muted);line-height:1.85;padding-left:1.1rem;position:relative;max-width:820px}
.ebl li::before{content:'—';position:absolute;left:0;color:var(--gold);opacity:.45}

/* Education */
.education{border-top:1px solid var(--border);background:var(--surface)}
.edg{display:grid;grid-template-columns:minmax(0,760px);gap:1.5rem}
.edc{border:1px solid var(--border);padding:2rem;background:rgba(11,11,10,.18);transition:border-color .2s,background .2s}
.edc:hover{border-color:rgba(200,169,110,.3)}
.esc{font-family:var(--serif);font-size:22px;font-weight:400;margin-bottom:5px;line-height:1.2}
.edeg{font-size:11px;color:var(--muted);margin-bottom:1rem}
.egpa{font-size:9px;letter-spacing:2px;text-transform:uppercase;color:var(--gold);border:1px solid rgba(200,169,110,.3);padding:3px 10px;display:inline-block}

/* Contact */
.contact{border-top:1px solid var(--border);text-align:center}
.ch{font-family:var(--serif);font-size:clamp(52px,8vw,110px);font-weight:300;font-style:italic;line-height:1;margin-bottom:1.75rem}
.cp{font-size:14.5px;color:var(--muted);max-width:460px;margin:0 auto;line-height:1.9}
.cl{display:flex;gap:2.5rem;justify-content:center;flex-wrap:wrap;margin-top:3rem}
.cl a{font-size:10px;letter-spacing:2px;text-transform:uppercase;color:var(--muted);transition:color .2s}
.cl a:hover{color:var(--gold)}
.contact-form{max-width:720px;margin:3rem auto 0;text-align:left;display:grid;grid-template-columns:1fr 1fr;gap:1rem}
.field{display:flex;flex-direction:column;gap:.5rem}
.field.full{grid-column:1/-1}
.field label{font-size:9px;letter-spacing:2px;text-transform:uppercase;color:var(--gold)}
.field input,.field textarea{width:100%;border:1px solid var(--border);background:rgba(247,240,230,.035);color:var(--cream);font:500 14px/1.6 var(--sans);padding:1rem 1.1rem;outline:none;transition:border-color .2s,background .2s}
.field textarea{min-height:150px;resize:vertical}
.field input:focus,.field textarea:focus{border-color:rgba(199,166,106,.55);background:rgba(247,240,230,.055)}
.form-actions{grid-column:1/-1;display:flex;justify-content:space-between;align-items:center;gap:1rem;flex-wrap:wrap;margin-top:.35rem}
.form-actions .btn-p{cursor:pointer}
.direct-link{font-size:10px;letter-spacing:1.8px;text-transform:uppercase;color:var(--muted);transition:color .2s}
.direct-link:hover{color:var(--gold)}

footer{padding:2rem 3rem;border-top:1px solid var(--border);display:flex;justify-content:space-between;align-items:center}
footer p{font-size:10px;color:var(--subtle);letter-spacing:1px}

/* Animations */
@keyframes up{from{opacity:0;transform:translateY(18px)}to{opacity:1;transform:none}}
@keyframes portraitDrift{0%,100%{transform:scale(1) translate3d(0,0,0)}50%{transform:scale(1.025) translate3d(-1.2%,.8%,0)}}
@keyframes heroLight{0%,100%{opacity:.55;transform:translateX(-8%)}50%{opacity:.9;transform:translateX(8%)}}
@keyframes heroFrame{0%,100%{transform:scale(1);opacity:.75}50%{transform:scale(.965);opacity:.35}}
@keyframes floatDoodle{0%,100%{transform:translate3d(0,0,0) rotate(0deg)}50%{transform:translate3d(0,-11px,0) rotate(2.5deg)}}
@keyframes drawTrace{0%,18%{stroke-dashoffset:78;opacity:.35}48%,78%{stroke-dashoffset:0;opacity:1}100%{stroke-dashoffset:-78;opacity:.35}}
@keyframes sparkleBlink{0%,100%{opacity:.25;transform:scale(.75) rotate(45deg)}50%{opacity:1;transform:scale(1.1) rotate(45deg)}}
@keyframes slowSpin{to{transform:rotate(360deg)}}
@keyframes pageTurnNext{0%{transform:rotateY(0) translateX(0);filter:brightness(1)}45%{transform:rotateY(-9deg) translateX(-8px);filter:brightness(.88)}100%{transform:rotateY(0) translateX(0);filter:brightness(1)}}
@keyframes pageTurnPrev{0%{transform:rotateY(0) translateX(0);filter:brightness(1)}45%{transform:rotateY(9deg) translateX(8px);filter:brightness(.9)}100%{transform:rotateY(0) translateX(0);filter:brightness(1)}}
.rev{opacity:0;transform:translateY(22px);transition:opacity .75s ease,transform .75s ease}
.rev.vis{opacity:1;transform:none}

@media(max-width:1180px){
  .work-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
  .hero{grid-template-columns:minmax(0,1fr) minmax(320px,.78fr)}
  .modal-inner{max-width:100%;padding-left:clamp(1.5rem,4vw,3rem);padding-right:clamp(1.5rem,4vw,3rem)}
  .ag{grid-template-columns:minmax(260px,.8fr) minmax(0,1fr);gap:clamp(2.5rem,5vw,4rem)}
}

/* Mobile */
@media(max-width:900px){
  body{cursor:default}
  a,.btn-p,.btn-o,.wcard-wrap,.modal-close{cursor:pointer}
  nav{padding:1.2rem 1.5rem}
  .nav-links{display:none}
  .hero{grid-template-columns:1fr}
  .hero-left{min-height:72vh;padding:7rem 1.5rem 3rem}
  .hero-right{height:min(76vw,520px);grid-row:1}
  .doodle{width:clamp(34px,10vw,60px)}
  .hero-name{font-size:clamp(64px,18vw,104px)}
  section{padding:4rem 1.5rem}
  .work{padding:4rem 0 0}
  .work>.sec-label{padding:0 1.5rem}
  .work-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
  .wcard{aspect-ratio:1/1}
  .wcard-overlay{opacity:1}
  .cn{opacity:1}
  .ag{grid-template-columns:1fr;gap:2.5rem}
  .sg{grid-template-columns:repeat(2,1fr)}
  .ei{grid-template-columns:1fr;gap:.5rem}
  .edg{grid-template-columns:1fr}
  .modal-inner{padding:4rem 1.5rem 5rem}
  .modal-close{right:1.5rem}
  .modal-header{flex-wrap:wrap;gap:1rem}
  .modal-meta{text-align:left}
  .modal-grid-2{grid-template-columns:1fr}
  .modal-grid-3{grid-template-columns:1fr 1fr}
  .project-details{grid-template-columns:1fr}
  .brand-grid{grid-template-columns:1fr}
  .contact-form{grid-template-columns:1fr}
  .flipbook-spread{grid-template-columns:1fr}
  .flipbook-spread::before{display:none}
  .flipbook-stage{padding:1rem}
  .flip-page{max-width:560px;margin:0 auto;width:100%}
  footer{flex-direction:column;gap:.5rem;text-align:center}
  .to-top{width:38px;height:38px;right:1rem;bottom:1rem}
}
@media(max-width:620px){
  body{font-size:14px}
  .hero-left{min-height:64vh}
  .hero-right{height:88vw}
  .hero-sub{line-height:1.75}
  .cta-row{display:grid;grid-template-columns:1fr;width:100%}
  .btn-p,.btn-o{width:100%}
  .stats{grid-template-columns:1fr;gap:1.25rem}
  .work-grid{grid-template-columns:1fr;border-left:0}
  .wcard-wrap{border-right:0}
  .wcard-footer{min-height:auto;padding:1.1rem 1.5rem 1.2rem}
  .sg{grid-template-columns:1fr}
  .sk{border-right:0}
  .proj-products,.sip-variants{grid-template-columns:1fr}
  .modal-grid-3{grid-template-columns:1fr}
  .modal-grid-asym{grid-template-columns:1fr}
  .modal-caption{gap:1rem;flex-wrap:wrap}
  .pop-gallery{gap:6px}
  .pop-caption{grid-template-columns:repeat(2,minmax(0,1fr))}
  .flipbook-toolbar{align-items:flex-start;flex-direction:column}
  .flipbook-nav{width:100%}
  .flip-btn{flex:1;cursor:pointer}
  .flipbook-wrap{padding:.75rem}
  .flipbook-stage{padding:.65rem}
  .modal-title{font-size:clamp(38px,13vw,58px)}
  .modal-desc{font-size:13.5px;line-height:1.8}
  .pd{padding:1.1rem}
  .form-actions .btn-p{width:100%}
  .direct-link{width:100%;text-align:center}
  .cl{gap:1.25rem}
  .cl a{width:100%}
}
/* Responsive hardening */
html,
body{
  max-width:100%;
  overflow-x:hidden;
}

body{
  min-width:0;
}

h1,h2,h3,p,a,button,
.hero-name,.modal-title,.wtitle,.wf-title,.ah,.ch,.esc,.eco{
  overflow-wrap:anywhere;
}

nav,
.hero,
.work,
.about,
.experience,
.education,
.contact,
.modal-bg,
.modal-inner,
.work-grid,
.project-details,
.modal-grid-2,
.modal-grid-3,
.modal-grid-asym,
.pop-gallery,
.brand-grid,
.contact-form,
.flipbook-spread{
  min-width:0;
}

.logo,.nav-links a,.btn-p,.btn-o,.direct-link,.cl a,.flip-btn{
  white-space:nowrap;
}

.wcard-img img,
.modal-hero img,
.modal-grid-2 img,
.modal-grid-3 img,
.modal-grid-asym img,
.pop-gallery img,
.sip-print-img img,
.flip-page img,
.live-thumb img{
  max-width:100%;
}

.modal-caption.pop-caption{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  align-items:start;
  justify-content:stretch;
  gap:.75rem;
}

.contact-form,
.field,
.field input,
.field textarea{
  min-width:0;
}

@media(max-width:1180px){
  .modal-grid-asym{grid-template-columns:1fr 1.4fr}
  .nav-links{gap:1.35rem}
}

@media(max-width:900px){
  html{scroll-padding-top:118px}
  nav{
    max-width:100vw;
    padding:1rem 1.25rem;
    align-items:flex-start;
    gap:.85rem;
    flex-wrap:wrap;
    max-height:42vh;
    overflow:hidden;
  }
  .nav-links{
    display:flex;
    order:3;
    width:100%;
    gap:.85rem;
    overflow-x:auto;
    padding:.25rem 0 .1rem;
    scrollbar-width:none;
    -webkit-overflow-scrolling:touch;
  }
  .nav-links::-webkit-scrollbar{display:none}
  .nav-links a{
    font-size:9px;
    letter-spacing:1.45px;
    line-height:1.2;
    flex:0 0 auto;
  }
  .hero{min-height:auto}
  .hero-left{
    min-height:auto;
    padding-top:calc(6.75rem + 28px);
  }
  .hero-right{
    height:clamp(360px,80vw,560px);
  }
  .hero-name{letter-spacing:0}
  .hero-sub{max-width:36rem}
  .cta-row{gap:.85rem}
  .ah{
    font-size:clamp(42px,9.5vw,72px);
    letter-spacing:0;
  }
  .modal-header{align-items:flex-start}
  .modal-title{
    letter-spacing:0;
    max-width:100%;
  }
  .project-details{gap:1px}
  .sip-variants{grid-template-columns:repeat(2,minmax(0,1fr))}
  .live-site-frame{
    height:min(78vh,680px);
    min-height:480px;
  }
  .flipbook-nav{gap:.5rem}
}

@media(max-width:620px){
  html{scroll-padding-top:116px}
  nav{padding:.85rem 1rem}
  .logo{
    font-size:20px;
    line-height:1.1;
  }
  .nav-links{
    gap:.72rem;
    margin-left:-.05rem;
  }
  .nav-links a{
    font-size:8.5px;
    letter-spacing:1.2px;
  }
  .hero-left{
    padding:6.4rem 1.1rem 2.5rem;
  }
  .hero-right{
    height:min(118vw,520px);
    min-height:360px;
  }
  .eyebrow,.sec-label,.res-label,.tl{letter-spacing:2.1px}
  .hero-name{
    font-size:clamp(54px,18vw,78px);
    line-height:.94;
  }
  .hero-sub{
    font-size:14.5px;
    line-height:1.8;
  }
  .cta-row{
    margin-top:1.75rem;
    gap:.75rem;
  }
  .btn-p,.btn-o{
    min-height:46px;
    padding:.95rem 1rem;
    letter-spacing:1.6px;
  }
  section{padding:3.4rem 1.1rem}
  .work{padding-top:3.4rem}
  .work>.sec-label{padding:0 1.1rem}
  .wcard-footer{
    gap:.55rem;
    padding:.9rem 1rem;
  }
  .wf-title{font-size:17px}
  .wf-cat{letter-spacing:1.2px}
  .modal-inner{padding:3.6rem 1rem 4.5rem}
  .modal-close{right:1rem;top:1rem}
  .modal-title{
    font-size:clamp(34px,12.5vw,52px);
    line-height:1;
  }
  .modal-cat,.modal-sub{letter-spacing:1.5px}
  .modal-desc{
    max-width:100%;
    font-size:14px;
    line-height:1.85;
  }
  .modal-caption span{max-width:100%}
  .sip-variants{grid-template-columns:1fr}
  .live-site-frame{
    height:70vh;
    min-height:420px;
  }
  .flipbook-nav{
    display:grid;
    grid-template-columns:1fr 1fr;
    width:100%;
  }
  .flip-status{
    grid-column:1/-1;
    text-align:center;
  }
  .ch{font-size:clamp(42px,14vw,64px)}
  .cp{font-size:14px}
  footer{padding:1.6rem 1rem}
}

@media(max-width:430px){
  .hero-left{
    padding-left:1rem;
    padding-right:1rem;
  }
  .hero-right{
    height:min(130vw,500px);
    min-height:330px;
  }
  .hero-name{font-size:clamp(48px,17vw,68px)}
  .modal-grid-2,
  .modal-grid-3,
  .modal-grid-asym{gap:.75rem}
  .pop-gallery{gap:8px}
  .to-top{
    width:36px;
    height:36px;
    font-size:16px;
  }
}

@media(min-width:901px) and (max-width:1180px){
  .nav-links{gap:1.4rem}
  .nav-links a{letter-spacing:1.8px}
}

@media(hover:none),(pointer:coarse){
  body,a,button,.btn-p,.btn-o,.direct-link,.to-top{
    cursor:default;
  }
}
