/* ============================================================
   Samuel Fernley — portfolio
   Light · Cormorant serif display + Schibsted sans · hover-reveal top nav
   ============================================================ */

@import url('https://fonts.googleapis.com/css2?family=Cormorant+Garamond:ital,wght@0,500;0,600;1,500&family=Schibsted+Grotesk:wght@400;500;600;700&display=swap');

:root {
  --bg:#fbfbf9; --panel:#ffffff; --panel-2:#f6f5f1; --line:#e6e5df; --line-soft:#efeee9;
  --text:#1b1f26; --text-2:#565a62; --text-3:#8a8e95;
  --accent:#213c5e; --accent-hi:#2e527e; --accent-soft:rgba(33,60,94,.07);
  --maxw:1080px; --r:4px;
  --shadow-sm:0 1px 2px rgba(27,31,38,.05); --shadow-md:0 8px 26px rgba(27,31,38,.10); --shadow-lg:0 26px 64px rgba(27,31,38,.20);
  --serif:'Cormorant Garamond',Georgia,'Times New Roman',serif;
  --sans:'Schibsted Grotesk',-apple-system,BlinkMacSystemFont,'Segoe UI',sans-serif;
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;}
html{-webkit-text-size-adjust:100%;scroll-behavior:smooth;}
body{font-family:var(--sans);color:var(--text);background:var(--bg);line-height:1.62;font-size:17px;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;}
img{max-width:100%;display:block;}
a{color:inherit;text-decoration:none;}
button{font:inherit;cursor:pointer;border:none;background:none;color:inherit;}
::selection{background:var(--accent);color:#fff;}
:focus-visible{outline:2px solid var(--accent);outline-offset:3px;border-radius:2px;}

h1,h2{font-family:var(--serif);font-weight:600;line-height:1.04;letter-spacing:-.005em;color:var(--text);}
h1{font-size:clamp(3.2rem,7.5vw,6rem);}
h2{font-size:clamp(2.1rem,4vw,3.1rem);}
h3,h4{font-family:var(--serif);font-weight:600;line-height:1.16;letter-spacing:0;}
h3{font-size:1.35rem;}
p{color:var(--text-2);}
.lead{font-size:clamp(1.04rem,1.5vw,1.2rem);color:var(--text-2);max-width:60ch;line-height:1.55;}
.eyebrow{font-size:.72rem;font-weight:600;letter-spacing:.15em;text-transform:uppercase;color:var(--text-3);margin-bottom:18px;}
.meta-line{font-size:.76rem;font-weight:500;letter-spacing:.07em;text-transform:uppercase;color:var(--text-3);}
.eyebrow[data-rise]{font-family:var(--serif);font-weight:600;font-size:1.5rem;letter-spacing:0;text-transform:none;color:var(--text);margin-bottom:16px;}

/* ---------- hover-reveal top nav ---------- */
.nav-trigger{position:fixed;top:0;left:0;right:0;height:26px;z-index:90;display:flex;align-items:flex-start;justify-content:center;}
.nav-trigger::after{content:"";margin-top:8px;width:42px;height:4px;border-radius:4px;background:var(--text-3);opacity:.35;transition:opacity .2s ease,width .2s ease;}
.nav-trigger:hover::after{opacity:.7;width:54px;}
body.nav-show .nav-trigger::after{opacity:0;}

.topnav{position:fixed;top:0;left:0;right:0;z-index:100;background:rgba(251,251,249,.93);backdrop-filter:blur(8px);border-bottom:1px solid var(--line);transform:translateY(-100%);transition:transform .32s cubic-bezier(.2,.7,.2,1);box-shadow:var(--shadow-md);}
body.nav-show .topnav{transform:none;}
.topnav__inner{max-width:var(--maxw);margin:0 auto;padding:14px clamp(20px,5vw,48px);display:flex;align-items:center;gap:24px;}
.topnav__brand{font-family:var(--serif);font-weight:600;font-size:1.32rem;letter-spacing:0;}
.topnav__links{display:flex;align-items:center;gap:4px;margin-left:auto;}
.topnav__links a{font-family:var(--serif);padding:6px 14px;border-radius:var(--r);font-size:1.18rem;font-weight:600;color:var(--text-2);transition:background .16s ease,color .16s ease;}
.topnav__links a:hover{background:var(--panel-2);color:var(--text);}
.topnav__links a.is-active{color:var(--accent);font-weight:600;}
.topnav__cv{display:inline-flex;align-items:center;gap:8px;padding:6px 16px !important;border-radius:var(--r);background:var(--accent);color:#fff !important;font-family:var(--serif);font-size:1.12rem;font-weight:600;}
.topnav__cv:hover{background:var(--accent-hi) !important;}
.topnav__cv svg{width:14px;height:14px;}
.topnav__burger{display:none;margin-left:auto;width:40px;height:40px;border-radius:var(--r);place-items:center;color:var(--text);}
.topnav__burger svg{width:22px;height:22px;}

/* ---------- page ---------- */
.content{min-height:100vh;display:flex;flex-direction:column;}
.wrap{width:100%;max-width:var(--maxw);margin:0 auto;padding:0 clamp(24px,5vw,48px);}
.section{padding:clamp(46px,6vw,80px) 0;border-bottom:1px solid var(--line);}
.section:last-of-type{border-bottom:none;}
.hero{padding:clamp(70px,11vw,150px) 0 clamp(40px,5vw,64px);border-bottom:1px solid var(--line);}
.hero h1{margin-bottom:24px;}
.hero__cta{display:flex;flex-wrap:wrap;gap:13px;margin-top:30px;}
.hero--home{display:grid;grid-template-columns:1.25fr .75fr;gap:clamp(32px,5vw,64px);align-items:center;}
.hero__portrait{width:100%;aspect-ratio:4/5;border-radius:var(--r);background:var(--panel);border:1px solid var(--line);position:relative;overflow:hidden;}
.hero__portrait::after{content:"Portrait \00B7 4:5 \2014 add assets/images/portrait.jpg";position:absolute;inset:0;display:grid;place-content:center;text-align:center;padding:20px;font-size:.66rem;font-weight:500;letter-spacing:.07em;text-transform:uppercase;color:var(--text-3);}
.hero__portrait img{width:100%;height:100%;object-fit:cover;}
.prose{max-width:70ch;}
.prose p+p{margin-top:1.1em;}

.btn{display:inline-flex;align-items:center;gap:9px;padding:13px 24px;border-radius:var(--r);font-weight:600;font-size:.9rem;transition:transform .18s ease,background .18s ease,color .18s ease,border-color .18s ease;}
.btn--solid{background:var(--accent);color:#fff;}
.btn--solid:hover{background:var(--accent-hi);transform:translateY(-2px);}
.btn--ghost{border:1px solid var(--line);color:var(--text);}
.btn--ghost:hover{border-color:var(--accent);color:var(--accent);}
.btn svg{width:16px;height:16px;}

/* explore (home) */
.explore{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-top:30px;}
.ecard{background:var(--panel);border:1px solid var(--line);border-radius:var(--r);padding:24px 22px;display:flex;align-items:baseline;justify-content:space-between;gap:12px;transition:border-color .2s ease,transform .2s ease;}
.ecard:hover{border-color:var(--accent);transform:translateY(-2px);}
.ecard h3{font-family:var(--serif);font-weight:600;font-size:1.5rem;}
.ecard .arr{color:var(--accent);transition:transform .2s ease;}
.ecard:hover .arr{transform:translateX(4px);}

/* entry */
.entry{display:grid;grid-template-columns:180px 1fr;gap:40px;padding:38px 0;border-top:1px solid var(--line);}
.entry:first-of-type{border-top:none;}
.entry__logo{width:80px;height:80px;border-radius:var(--r);background:var(--panel);border:1px solid var(--line);display:grid;place-content:center;font-size:.55rem;font-weight:600;letter-spacing:.05em;text-transform:uppercase;color:var(--text-3);text-align:center;padding:8px;margin-bottom:12px;}
.entry__when{font-size:.75rem;font-weight:600;letter-spacing:.05em;text-transform:uppercase;color:var(--text-3);}
.entry h3{margin-bottom:4px;font-size:1.55rem;}
.entry__sub{font-size:.8rem;font-weight:500;letter-spacing:.03em;text-transform:uppercase;color:var(--text-3);margin-bottom:14px;}
.subgrid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-top:22px;}
.subgrid h4{font-size:1.1rem;font-weight:600;letter-spacing:0;color:var(--text);margin-bottom:5px;}
.subgrid p{font-size:.89rem;}

/* engagements */
.eng-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:14px;margin-top:30px;}
.engagement__open{width:100%;text-align:left;background:var(--panel);border:1px solid var(--line);border-radius:var(--r);padding:24px;display:flex;flex-direction:column;min-height:150px;transition:transform .2s ease,border-color .2s ease,box-shadow .2s ease;}
.engagement__open:hover{transform:translateY(-3px);border-color:var(--accent);box-shadow:var(--shadow-md);}
.engagement__top{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px;}
.engagement__num{font-size:.78rem;font-weight:700;color:var(--accent);}
.engagement__tag{font-size:.61rem;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:var(--text-3);padding:4px 11px;border:1px solid var(--line);border-radius:100px;}
.engagement__title{font-family:var(--serif);font-size:1.3rem;line-height:1.22;flex:1;font-weight:600;}
.engagement--ph .engagement__title{color:var(--text-3);font-weight:400;}
.engagement__cue{font-size:.8rem;font-weight:600;color:var(--accent);margin-top:16px;display:flex;align-items:center;gap:8px;}
.engagement__cue .arr{transition:transform .2s ease;}
.engagement__open:hover .engagement__cue .arr{transform:translateX(5px);}
.engagement__detail{display:none;}
dialog.eng-modal{border:none;padding:0;border-radius:6px;max-width:640px;width:calc(100% - 40px);background:var(--panel);color:var(--text);box-shadow:var(--shadow-lg);overflow:visible;}
dialog.eng-modal::backdrop{background:rgba(27,31,38,.5);backdrop-filter:blur(3px);}
.eng-modal__inner{padding:36px clamp(26px,4vw,44px) 38px;max-height:82vh;overflow-y:auto;}
.eng-modal__close{position:absolute;top:13px;right:13px;width:38px;height:38px;border-radius:50%;display:grid;place-items:center;background:var(--bg);border:1px solid var(--line);color:var(--text-2);transition:background .16s ease,color .16s ease,transform .16s ease;}
.eng-modal__close:hover{background:var(--accent);color:#fff;transform:rotate(90deg);}
.eng-modal__inner h3{font-family:var(--serif);font-weight:600;font-size:1.9rem;margin-bottom:16px;}
.eng-modal__inner p{margin-bottom:1em;}
.eng-facts{display:grid;grid-template-columns:1fr 1fr;gap:1px;background:var(--line);border:1px solid var(--line);border-radius:var(--r);margin:20px 0;overflow:hidden;}
.eng-facts div{background:var(--panel);padding:14px 18px;}
.eng-facts dt{font-size:.6rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--text-3);margin-bottom:5px;}
.eng-facts dd{font-size:.9rem;color:var(--text);}
.ph-note{font-size:.8rem;font-weight:500;color:var(--accent);background:var(--accent-soft);border-left:3px solid var(--accent);padding:10px 14px;border-radius:2px;margin:16px 0;}

/* projects */
.project{padding:clamp(38px,5vw,56px) 0;border-top:1px solid var(--line);scroll-margin-top:30px;}
.project:first-of-type{border-top:none;}
.project__head{display:flex;align-items:baseline;gap:16px;flex-wrap:wrap;margin-bottom:8px;}
.project__kicker{font-size:.7rem;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:var(--text-3);}
.project__when{font-size:.72rem;font-weight:500;letter-spacing:.03em;text-transform:uppercase;color:var(--text-3);margin-left:auto;}
.project h2{margin-bottom:16px;}
.project__body{display:grid;grid-template-columns:1.3fr 1fr;gap:clamp(28px,4vw,50px);align-items:start;}
.project__media{border-radius:var(--r);background:var(--panel);border:1px solid var(--line);aspect-ratio:16/10;position:relative;overflow:hidden;}
.project__media::after{content:attr(data-label);position:absolute;inset:0;display:grid;place-content:center;text-align:center;padding:20px;font-size:.68rem;font-weight:500;letter-spacing:.07em;text-transform:uppercase;color:var(--text-3);}
.stat-row{display:flex;flex-wrap:wrap;gap:12px;margin:22px 0;}
.stat{background:var(--panel);border:1px solid var(--line);border-radius:var(--r);padding:15px 20px;min-width:112px;}
.stat b{font-family:var(--serif);font-size:2.1rem;font-weight:600;color:var(--text);display:block;line-height:1;}
.stat span{font-size:.64rem;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--text-3);margin-top:8px;display:block;}
.chiprow{display:flex;flex-wrap:wrap;gap:8px;margin-top:16px;}
.chip{font-size:.76rem;font-weight:500;padding:6px 13px;border:1px solid var(--line);border-radius:100px;color:var(--text-2);background:var(--panel);}
.proj-links{display:flex;flex-wrap:wrap;gap:16px;margin-top:20px;}
.text-link{font-size:.85rem;font-weight:600;color:var(--accent);border-bottom:1px solid var(--accent);padding-bottom:2px;transition:opacity .16s ease;}
.text-link:hover{opacity:.65;}
.gallery{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin-top:20px;}
.gallery .project__media{aspect-ratio:1;}

/* skills */
.skill-block{padding:30px 0;border-top:1px solid var(--line);display:grid;grid-template-columns:230px 1fr;gap:40px;}
.skill-block:first-of-type{border-top:none;}
.skill-block h3{font-family:var(--serif);font-weight:600;font-size:1.5rem;}
.skill-tags{display:flex;flex-wrap:wrap;gap:9px;align-content:start;}
.skill-tags .chip{font-size:.8rem;padding:8px 14px;}

/* library */
.writing{padding:28px 0;border-top:1px solid var(--line);}
.writing:first-of-type{border-top:none;}
.writing__meta{font-size:.73rem;font-weight:500;letter-spacing:.03em;text-transform:uppercase;color:var(--text-3);margin:6px 0 12px;}
.writing h3{font-family:var(--serif);font-weight:600;font-size:1.55rem;margin-bottom:6px;}
.writing p{max-width:76ch;font-size:.94rem;}
.filterbar{display:flex;flex-wrap:wrap;gap:8px;margin:26px 0 24px;}
.filterbar button{font-size:.76rem;font-weight:500;padding:8px 16px;border-radius:100px;border:1px solid var(--line);color:var(--text-2);background:var(--panel);transition:all .16s ease;}
.filterbar button:hover{border-color:var(--accent);color:var(--accent);}
.filterbar button.is-active{background:var(--accent);color:#fff;border-color:var(--accent);}
.podcasts{display:grid;grid-template-columns:repeat(2,1fr);gap:14px;}
.podcast{display:flex;gap:15px;padding:16px;background:var(--panel);border:1px solid var(--line);border-radius:var(--r);transition:transform .18s ease,border-color .18s ease;}
.podcast:hover{transform:translateY(-2px);border-color:var(--accent);}
.podcast__art{width:66px;height:66px;flex:0 0 66px;border-radius:var(--r);background:var(--bg);border:1px solid var(--line);overflow:hidden;}
.podcast__art img{width:100%;height:100%;object-fit:cover;}
.podcast h4{font-size:.98rem;font-weight:600;margin-bottom:3px;}
.podcast__by{font-size:.7rem;font-weight:600;letter-spacing:.02em;text-transform:uppercase;color:var(--text-3);margin-bottom:6px;}
.podcast__note{font-size:.81rem;color:var(--text-2);line-height:1.5;}
.bookshelf{display:flex;align-items:center;gap:16px;background:var(--panel);border:1px solid var(--line);border-radius:var(--r);padding:20px 24px;margin-top:8px;max-width:520px;transition:border-color .16s ease,transform .16s ease;}
.bookshelf:hover{border-color:var(--accent);transform:translateY(-2px);}
.bookshelf__icon{width:40px;height:40px;border-radius:var(--r);background:var(--accent-soft);color:var(--accent);display:grid;place-items:center;font-weight:700;}
.bookshelf b{font-size:1.02rem;color:var(--text);}
.bookshelf span{display:block;font-size:.84rem;color:var(--text-3);}

/* footer */
.foot{background:var(--bg);color:var(--text-3);padding:40px 0;margin-top:auto;border-top:1px solid var(--line);}
.foot .wrap{display:flex;flex-wrap:wrap;justify-content:space-between;gap:20px;align-items:center;}
.foot__name{color:var(--text);font-family:var(--serif);font-size:1.35rem;font-weight:600;}
.foot__links{display:flex;gap:22px;font-size:.82rem;font-weight:500;}
.foot__links a{color:var(--text-2);transition:color .16s ease;}
.foot__links a:hover{color:var(--accent);}

/* animation */
@keyframes rise{from{opacity:0;transform:translateY(14px);}to{opacity:1;transform:none;}}
.reveal{opacity:0;animation:rise .7s cubic-bezier(.2,.7,.2,1) forwards;}
.reveal:nth-child(1){animation-delay:.04s}.reveal:nth-child(2){animation-delay:.12s}.reveal:nth-child(3){animation-delay:.2s}.reveal:nth-child(4){animation-delay:.28s}
[data-rise]{opacity:0;}
[data-rise].in{animation:rise .7s cubic-bezier(.2,.7,.2,1) forwards;}
@media (prefers-reduced-motion:reduce){*,*::before,*::after{animation:none !important;transition:none !important;scroll-behavior:auto;}.reveal,[data-rise]{opacity:1}}

/* responsive */
@media (max-width:1080px){.project__body{grid-template-columns:1fr;}.subgrid{grid-template-columns:1fr;}.explore{grid-template-columns:1fr;}}
@media (max-width:860px){
  body{font-size:16px;}
  .hero--home{grid-template-columns:1fr;gap:28px;}
  .hero__portrait{max-width:300px;}
  .nav-trigger{display:none;}
  .topnav__inner{flex-wrap:wrap;gap:10px 16px;}
  .topnav__burger{display:grid;}
  .topnav__links{order:3;width:100%;margin-left:0;flex-direction:column;align-items:stretch;gap:2px;max-height:0;overflow:hidden;transition:max-height .28s ease;}
  .topnav__links.is-open{max-height:380px;padding-top:6px;}
  .topnav__cv{justify-content:center;margin-top:4px;}
  .eng-grid,.podcasts{grid-template-columns:1fr;}
  .entry,.skill-block{grid-template-columns:1fr;gap:14px;}
  .gallery{grid-template-columns:repeat(2,1fr);}
  .eng-facts{grid-template-columns:1fr;}
}

/* ---------- wired images + graceful fallbacks ---------- */
.fill{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:2;}
.fill--contain{object-fit:contain;padding:10px;}
.entry__logo{position:relative;overflow:hidden;}
.entry__logo::after{content:attr(data-label);position:absolute;inset:0;display:grid;place-content:center;font-size:.62rem;font-weight:600;letter-spacing:.05em;text-transform:uppercase;color:var(--text-3);text-align:center;padding:6px;z-index:0;}
.project__media--portrait{aspect-ratio:3/4;}

/* ---------- Calc-a-Mine "See preview" ---------- */
.preview-actions{margin-top:24px;}
.preview-toggle{display:inline-flex;align-items:center;gap:9px;padding:11px 22px;border-radius:var(--r);border:1px solid var(--accent);color:var(--accent);background:var(--panel);font-family:var(--serif);font-size:1.1rem;font-weight:600;transition:background .16s ease,color .16s ease;}
.preview-toggle:hover{background:var(--accent);color:#fff;}
.preview-gallery{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-top:14px;}
.preview-gallery.is-open{display:grid;}
.preview-hint{font-size:.82rem;color:var(--text-3);}
.project__full .prose{max-width:none;}
.project__full > * + *{margin-top:16px;}
.shot{display:block;width:100%;text-align:left;background:none;border:none;padding:0;cursor:pointer;font:inherit;}
.shot__thumb{display:block;position:relative;aspect-ratio:16/10;border:1px solid var(--line);border-radius:var(--r);overflow:hidden;background:var(--panel);transition:border-color .18s ease,transform .18s ease,box-shadow .18s ease;}
.shot__thumb img{width:100%;height:100%;object-fit:cover;object-position:top center;display:block;}
.shot:hover .shot__thumb,.shot:focus-visible .shot__thumb{border-color:var(--accent);transform:translateY(-2px);box-shadow:var(--shadow-md);}
.shot__thumb::after{content:"\2922";position:absolute;top:8px;right:8px;width:26px;height:26px;display:grid;place-items:center;border-radius:4px;background:rgba(27,31,38,.62);color:#fff;font-size:.85rem;opacity:0;transition:opacity .18s ease;}
.shot:hover .shot__thumb::after{opacity:1;}
.shot__cap{display:block;font-size:.78rem;color:var(--text-3);margin-top:9px;letter-spacing:.02em;}
.shot.is-missing .shot__thumb{border-style:dashed;background:var(--panel-2);}

/* lightbox */
dialog.lightbox{border:none;padding:0;background:transparent;max-width:96vw;max-height:96vh;overflow:visible;}
dialog.lightbox::backdrop{background:rgba(20,22,27,.88);backdrop-filter:blur(4px);}
.lightbox__img{display:block;max-width:92vw;max-height:84vh;width:auto;height:auto;margin:0 auto;border-radius:6px;box-shadow:var(--shadow-lg);background:#fff;}
.lightbox__cap{text-align:center;color:#f3f3f0;font-size:.9rem;margin-top:14px;letter-spacing:.02em;}
.lightbox__close{position:fixed;top:18px;right:20px;width:44px;height:44px;border-radius:50%;display:grid;place-items:center;background:rgba(255,255,255,.14);color:#fff;border:1px solid rgba(255,255,255,.28);transition:background .16s ease;}
.lightbox__close:hover{background:rgba(255,255,255,.28);}
.lightbox__close svg{width:20px;height:20px;}
.lightbox__nav{position:fixed;top:50%;transform:translateY(-50%);width:52px;height:52px;border-radius:50%;display:grid;place-items:center;background:rgba(255,255,255,.14);color:#fff;border:1px solid rgba(255,255,255,.28);font-size:1.7rem;line-height:1;padding-bottom:4px;transition:background .16s ease;}
.lightbox__nav:hover{background:rgba(255,255,255,.28);}
.lightbox__prev{left:18px;}
.lightbox__next{right:18px;}
@media (max-width:980px){.preview-gallery{grid-template-columns:repeat(2,1fr);}}
@media (max-width:860px){.preview-gallery{grid-template-columns:1fr;}}
