/* ===================================================================
   PORTFOLIO — MASTER STYLESHEET
   This one file controls how the WHOLE site looks.
   To recolour the entire site, change --accent on line ~20.
   =================================================================== */

/* ---- 1. DESIGN TOKENS ---- */
:root{
  --bg:        #FCFBF8;
  --surface:   #FFFFFF;
  --ink:       #17170F;
  --ink-soft:  #2A2A20;
  --muted:     #6E6E64;
  --line:      #E7E4DC;
  --accent:    #FF5B2E;   /* <<<<<<  BRAND COLOUR — change this one line  >>>>>> */
  --accent-ink:#FFFFFF;

  --max: 1180px;
  --radius: 18px;
  --radius-sm: 12px;

  --display: "Bricolage Grotesque", system-ui, sans-serif;
  --body: "Inter", system-ui, -apple-system, sans-serif;
  --ease: cubic-bezier(.22,.61,.36,1);
}

/* ---- 2. BASE ---- */
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{background:var(--bg);color:var(--ink);font-family:var(--body);font-size:16px;line-height:1.6;-webkit-font-smoothing:antialiased;overflow-x:hidden}
a{color:inherit;text-decoration:none}
img{display:block;max-width:100%}
section{scroll-margin-top:90px}
.wrap{max-width:var(--max);margin:0 auto;padding:0 24px}

h1,h2,h3,h4{font-family:var(--display);line-height:1.04;letter-spacing:-.02em;font-weight:700}

.eyebrow{font-size:.72rem;letter-spacing:.18em;text-transform:uppercase;color:var(--muted);font-weight:600;display:inline-flex;align-items:center;gap:.55rem}
.eyebrow::before{content:"";width:22px;height:1px;background:var(--accent);display:inline-block}

/* ---- 3. BUTTONS ---- */
.btn{display:inline-flex;align-items:center;gap:.5rem;font-family:var(--body);font-weight:600;font-size:.95rem;padding:.85rem 1.4rem;border-radius:100px;border:1px solid var(--ink);transition:transform .2s var(--ease),background .2s var(--ease),color .2s var(--ease);cursor:pointer;background:transparent;color:var(--ink)}
.btn:hover{transform:translateY(-2px)}
.btn-solid{background:var(--ink);color:var(--bg);border-color:var(--ink)}
.btn-solid:hover{background:var(--accent);border-color:var(--accent);color:var(--accent-ink)}
.btn-accent{background:var(--accent);border-color:var(--accent);color:var(--accent-ink)}
.btn .arrow{transition:transform .2s var(--ease)}
.btn:hover .arrow{transform:translate(3px,-3px)}

/* ---- 4. NAV ---- */
header.nav{position:sticky;top:0;z-index:100;backdrop-filter:saturate(180%) blur(12px);background:color-mix(in srgb,var(--bg) 82%,transparent);border-bottom:1px solid var(--line)}
.nav-inner{display:flex;align-items:center;justify-content:space-between;height:72px}
.brand{display:flex;align-items:center;gap:.7rem;font-family:var(--display);font-weight:700;font-size:1.05rem}
.brand .mark{width:34px;height:34px;border-radius:50%;background:var(--ink);color:var(--bg);display:grid;place-items:center;font-size:.85rem;font-weight:700}
.nav-links{display:flex;align-items:center;gap:2rem;list-style:none}
.nav-links a{font-size:.92rem;font-weight:500;color:var(--ink-soft);position:relative;padding:.2rem 0}
.nav-links a::after{content:"";position:absolute;left:0;bottom:-3px;height:2px;width:0;background:var(--accent);transition:width .25s var(--ease)}
.nav-links a:hover::after,.nav-links a.active::after{width:100%}
.nav-links a.active{color:var(--ink)}
.nav-right{display:flex;align-items:center;gap:1.1rem}
.badge{display:inline-flex;align-items:center;gap:.5rem;font-size:.82rem;font-weight:600;color:var(--ink-soft);border:1px solid var(--line);border-radius:100px;padding:.45rem .85rem;background:var(--surface)}
.dot{width:8px;height:8px;border-radius:50%;background:#22b455;position:relative}
.dot::after{content:"";position:absolute;inset:-4px;border-radius:50%;border:2px solid #22b455;opacity:.6;animation:ping 1.8s infinite}
@keyframes ping{0%{transform:scale(.6);opacity:.7}100%{transform:scale(1.6);opacity:0}}
.menu-btn{display:none;background:none;border:none;cursor:pointer;width:40px;height:40px}
.menu-btn span{display:block;width:22px;height:2px;background:var(--ink);margin:4px auto;transition:.3s}

/* ---- 5. HERO ---- */
.hero{padding:84px 0 64px;position:relative}
.hero-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:56px;align-items:center}
.hero h1{font-size:clamp(4.2rem,13vw,11rem);font-weight:800;letter-spacing:-.045em;line-height:.86;margin-top:18px}
.hero h1 .line2{color:var(--accent)}
.hero-sub{margin-top:26px;max-width:30ch;font-size:1.15rem;color:var(--muted)}
.hero-cta{margin-top:34px;display:flex;gap:14px;flex-wrap:wrap}
.hero-media{position:relative;height:520px}
.portrait{position:absolute;border-radius:var(--radius);overflow:hidden;border:1px solid var(--line);background:repeating-linear-gradient(135deg,#f3f1ea 0 14px,#efece4 14px 28px);box-shadow:0 30px 60px -30px rgba(0,0,0,.25)}
.portrait img{width:100%;height:100%;object-fit:cover}
.portrait .ph-label{position:absolute;inset:0;display:none;place-items:center;text-align:center;color:var(--muted);font-size:.82rem;padding:1rem}
.portrait.ph-on .ph-label{display:grid}
.portrait.back{width:62%;height:78%;top:0;right:0;z-index:1}
.portrait.back.deco{background:color-mix(in srgb,var(--accent) 16%,var(--bg))}
.portrait.front{width:58%;height:70%;bottom:0;left:0;z-index:2;transform:rotate(-2deg)}
.tag-float{position:absolute;z-index:3;bottom:24px;right:8px;background:var(--ink);color:var(--bg);border-radius:100px;font-size:.8rem;font-weight:600;padding:.5rem .9rem;display:flex;align-items:center;gap:.45rem}

/* ---- 6. ABOUT + STATS ---- */
.about{padding:72px 0}
.about-head{display:grid;grid-template-columns:.8fr 1.2fr;gap:48px;align-items:start}
.about h2{font-size:clamp(2rem,4vw,3rem);margin-top:14px}
.about-bio{font-size:1.15rem;color:var(--ink-soft);max-width:54ch}
.stats{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-top:54px}
.stat{border:1px solid var(--line);border-radius:var(--radius);background:var(--surface);padding:30px 26px}
.stat .num{font-family:var(--display);font-weight:700;font-size:clamp(2.6rem,5vw,3.4rem);line-height:1;letter-spacing:-.03em}
.stat .lab{margin-top:8px;color:var(--muted);font-size:.95rem}

/* ---- 7. CLIENT LOGO SLIDER (continuous marquee) ---- */
.logos{padding:42px 0 8px}
.logos-label{text-align:center;color:var(--muted);font-size:.74rem;letter-spacing:.18em;text-transform:uppercase;font-weight:600;margin-bottom:26px}
.marquee{overflow:hidden;-webkit-mask-image:linear-gradient(90deg,transparent,#000 8%,#000 92%,transparent);mask-image:linear-gradient(90deg,transparent,#000 8%,#000 92%,transparent)}
.marquee-track{display:flex;align-items:center;gap:56px;width:max-content;animation:marquee 34s linear infinite}
.marquee:hover .marquee-track{animation-play-state:paused}
@keyframes marquee{from{transform:translateX(0)}to{transform:translateX(-50%)}}
.logo-item{height:46px;display:flex;align-items:center;justify-content:center;flex:0 0 auto;color:var(--muted);opacity:.75;transition:opacity .2s,filter .2s;filter:grayscale(1)}
.logo-item:hover{opacity:1;filter:grayscale(0)}
.logo-item img{height:100%;width:auto;object-fit:contain}
.logo-box{min-width:150px;height:46px;border:1px dashed var(--line);border-radius:10px;display:grid;place-items:center;font-size:.8rem;font-weight:600;letter-spacing:.04em;background:var(--surface)}

/* ---- 8. CONTACT ROW (about section + footer) ---- */
.about-contact{margin-top:40px;display:flex;flex-wrap:wrap;gap:36px;align-items:center;border-top:1px solid var(--line);padding-top:30px}
.ci-label{font-size:.72rem;letter-spacing:.16em;text-transform:uppercase;color:var(--muted);font-weight:600}
.ci-value{font-weight:600;font-size:1.02rem}
.ci-value:hover{color:var(--accent)}
.socials{display:flex;gap:12px;margin-left:auto}
.socials a{width:42px;height:42px;border-radius:50%;border:1px solid var(--line);display:grid;place-items:center;background:var(--surface);transition:.2s var(--ease)}
.socials a:hover{background:var(--ink);color:var(--bg);transform:translateY(-2px)}
.socials svg{width:18px;height:18px}

/* ---- 9. SHARED SECTION HEADER ---- */
.sec-head{max-width:640px;margin-bottom:40px}
.sec-head h2{font-size:clamp(2rem,4.5vw,3.2rem);margin:14px 0 12px}
.sec-head p{color:var(--muted);font-size:1.08rem}

/* ---- 10. PROJECT CARDS ---- */
.projects{padding:72px 0}
.proj-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:24px}
.card{border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;background:var(--surface);transition:transform .3s var(--ease),box-shadow .3s var(--ease);display:flex;flex-direction:column}
.card:hover{transform:translateY(-6px);box-shadow:0 26px 50px -28px rgba(0,0,0,.3)}
.card-img{aspect-ratio:16/10;background:repeating-linear-gradient(135deg,#f3f1ea 0 16px,#eeeae1 16px 32px);display:grid;place-items:center;color:var(--muted);font-size:.8rem;position:relative;overflow:hidden}
.card-img img{width:100%;height:100%;object-fit:cover;position:absolute;inset:0}
.card-body{padding:24px 24px 26px}
.card .tag{font-size:.7rem;letter-spacing:.14em;text-transform:uppercase;color:var(--accent);font-weight:700}
.card h3{font-size:1.45rem;margin:10px 0 8px}
.card p{color:var(--muted);font-size:.97rem}
.card .more{margin-top:16px;font-weight:600;font-size:.92rem;display:inline-flex;align-items:center;gap:.4rem}
.card:hover .more .arrow{transform:translate(3px,-3px)}
.center-btn{text-align:center;margin-top:42px}

/* ---- 11. BLOG CARDS ---- */
.blogs{padding:72px 0}
.blog-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.blog-card{border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;background:var(--surface);transition:transform .3s var(--ease),box-shadow .3s var(--ease)}
.blog-card:hover{transform:translateY(-6px);box-shadow:0 26px 50px -28px rgba(0,0,0,.3)}
.blog-img{aspect-ratio:16/9;background:repeating-linear-gradient(135deg,#f3f1ea 0 16px,#eeeae1 16px 32px);overflow:hidden;position:relative}
.blog-img img{width:100%;height:100%;object-fit:cover;position:absolute;inset:0}
.blog-body{padding:22px}
.blog-meta{display:flex;gap:.6rem;align-items:center;font-size:.72rem;text-transform:uppercase;letter-spacing:.1em;color:var(--muted);font-weight:600}
.blog-meta .cat{color:var(--accent)}
.blog-card h3{font-size:1.2rem;margin:12px 0 8px;line-height:1.18}
.blog-card p{color:var(--muted);font-size:.92rem}

/* ---- 12. CTA BAND ---- */
.cta{padding:40px 0 88px}
.cta-inner{background:var(--ink);color:var(--bg);border-radius:28px;padding:72px 56px;text-align:center;position:relative;overflow:hidden}
.cta-inner::before{content:"";position:absolute;width:480px;height:480px;border-radius:50%;background:radial-gradient(circle,var(--accent),transparent 62%);opacity:.4;top:-180px;right:-120px}
.cta h2{font-size:clamp(2.4rem,5vw,3.6rem);position:relative}
.cta p{max-width:46ch;margin:18px auto 30px;color:#cfcfc6;font-size:1.1rem;position:relative}
.cta .btn-accent{position:relative}

/* ---- 13. PAGE HEADER (inner pages) ---- */
.page-head{padding:72px 0 40px;border-bottom:1px solid var(--line)}
.page-head h1{font-size:clamp(3rem,8vw,6rem);font-weight:800;letter-spacing:-.04em;margin-top:16px}
.page-head p{color:var(--muted);font-size:1.15rem;max-width:56ch;margin-top:18px}

/* ---- 14. ABOUT PAGE ---- */
.about-page{padding:64px 0}
.about-split{display:grid;grid-template-columns:1fr 1fr;gap:56px;align-items:start}
.about-photo{border-radius:var(--radius);overflow:hidden;border:1px solid var(--line);background:repeating-linear-gradient(135deg,#f3f1ea 0 14px,#efece4 14px 28px);aspect-ratio:4/5;position:relative}
.about-photo img{width:100%;height:100%;object-fit:cover}
.about-photo .ph-label{position:absolute;inset:0;display:none;place-items:center;text-align:center;color:var(--muted);font-size:.85rem;padding:1rem}
.about-photo.ph-on .ph-label{display:grid}
.prose-block p{font-size:1.1rem;color:var(--ink-soft);margin-bottom:18px;max-width:60ch}
.skills{display:flex;flex-wrap:wrap;gap:10px;margin-top:8px}
.chip{border:1px solid var(--line);background:var(--surface);border-radius:100px;padding:.5rem 1rem;font-size:.9rem;font-weight:500}
.timeline{margin-top:14px;border-left:2px solid var(--line);padding-left:26px;display:flex;flex-direction:column;gap:30px}
.tl-item{position:relative}
.tl-item::before{content:"";position:absolute;left:-33px;top:5px;width:12px;height:12px;border-radius:50%;background:var(--accent)}
.tl-item .role{font-family:var(--display);font-weight:700;font-size:1.2rem}
.tl-item .org{color:var(--accent);font-weight:600;font-size:.95rem;margin:2px 0 6px}
.tl-item .when{color:var(--muted);font-size:.82rem;text-transform:uppercase;letter-spacing:.08em}
.tl-item p{color:var(--muted);margin-top:8px;font-size:.98rem}

/* ---- 15. ARTICLE / SINGLE POST + PROJECT ---- */
.article{padding:56px 0 72px}
.article-head{max-width:760px;margin:0 auto 36px}
.article-meta{display:flex;gap:.6rem;align-items:center;font-size:.74rem;text-transform:uppercase;letter-spacing:.1em;color:var(--muted);font-weight:600;margin-bottom:18px}
.article-meta .cat{color:var(--accent)}
.article-head h1{font-size:clamp(2.2rem,5vw,3.6rem);font-weight:800;letter-spacing:-.03em;line-height:1.05}
.article-cover{max-width:980px;margin:0 auto 40px;aspect-ratio:16/8;border-radius:var(--radius);overflow:hidden;border:1px solid var(--line);background:repeating-linear-gradient(135deg,#f3f1ea 0 16px,#eeeae1 16px 32px);position:relative}
.article-cover img{width:100%;height:100%;object-fit:cover}
.article-body{max-width:720px;margin:0 auto;font-size:1.12rem;line-height:1.75;color:var(--ink-soft)}
.article-body h2{font-size:1.7rem;margin:42px 0 14px;color:var(--ink)}
.article-body h3{font-size:1.3rem;margin:32px 0 10px;color:var(--ink)}
.article-body p{margin-bottom:20px}
.article-body ul,.article-body ol{margin:0 0 20px 22px}
.article-body li{margin-bottom:8px}
.article-body a{color:var(--accent);text-decoration:underline;text-underline-offset:3px}
.article-body blockquote{border-left:3px solid var(--accent);padding:6px 20px;margin:24px 0;color:var(--ink);font-style:italic;background:var(--surface);border-radius:0 8px 8px 0}
.article-body img{border-radius:12px;margin:24px 0;border:1px solid var(--line)}
.article-body code{background:#f1eee6;padding:.15em .4em;border-radius:5px;font-size:.92em}
.article-back{max-width:720px;margin:0 auto 28px}
.article-back a{font-weight:600;color:var(--muted)}
.article-back a:hover{color:var(--accent)}

/* project meta facts */
.proj-facts{max-width:720px;margin:0 auto 36px;display:flex;flex-wrap:wrap;gap:30px;border:1px solid var(--line);border-radius:var(--radius);padding:24px 28px;background:var(--surface)}
.proj-facts .f .k{font-size:.72rem;text-transform:uppercase;letter-spacing:.12em;color:var(--muted);font-weight:600}
.proj-facts .f .v{font-weight:600;margin-top:4px}

/* ---- 16. SCROLL REVEAL ---- */
.reveal{opacity:0;transform:translateY(26px);transition:opacity .7s var(--ease),transform .7s var(--ease)}
.reveal.in{opacity:1;transform:none}

/* ---- 17. FOOTER ---- */
footer.site{border-top:1px solid var(--line);padding:56px 0 40px}
.foot-grid{display:flex;flex-wrap:wrap;gap:40px;justify-content:space-between}
.foot-col .ci-label{display:block;margin-bottom:6px}
.foot-col a{font-weight:600}
.foot-col a:hover{color:var(--accent)}
.foot-nav{display:flex;gap:20px;flex-wrap:wrap}
.foot-nav a{color:var(--muted);font-weight:500}
.foot-nav a:hover{color:var(--ink)}
.foot-bottom{margin-top:46px;padding-top:24px;border-top:1px solid var(--line);display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:16px;color:var(--muted);font-size:.9rem}
.to-top{display:inline-flex;align-items:center;gap:.4rem;font-weight:600;color:var(--ink)}

/* ---- 18. RESPONSIVE ---- */
@media (max-width:900px){
  .nav-links,.nav-right .badge{display:none}
  .menu-btn{display:block}
  .hero-grid{grid-template-columns:1fr;gap:30px}
  .hero-media{height:380px;order:-1}
  .about-head{grid-template-columns:1fr;gap:22px}
  .stats{grid-template-columns:1fr}
  .proj-grid,.blog-grid{grid-template-columns:1fr}
  .about-split{grid-template-columns:1fr;gap:30px}
  .cta-inner{padding:54px 28px}
  .nav-links.open{display:flex;position:absolute;top:72px;left:0;right:0;flex-direction:column;gap:0;background:var(--bg);border-bottom:1px solid var(--line);padding:8px 0}
  .nav-links.open li{width:100%}
  .nav-links.open a{display:block;padding:14px 24px;border-top:1px solid var(--line)}
}
@media (prefers-reduced-motion:reduce){
  *{animation:none!important;transition:none!important;scroll-behavior:auto}
  .reveal{opacity:1;transform:none}
}
