/*
Theme Name:   XEDNIV
Theme URI:    https://xedniv.com/
Description:  Tema portfolio standalone per Samuele Merga. Custom HTML/CSS/JS, niente page builder, niente dipendenze. Carica direttamente come homepage del sito.
Author:       Samuele Merga
Author URI:   https://xedniv.com/
Version:      1.0.0
Requires at least: 6.0
Tested up to: 6.6
Requires PHP: 7.4
License:      GNU General Public License v2 or later
License URI:  http://www.gnu.org/licenses/gpl-2.0.html
Text Domain:  xedniv
Tags:         portfolio, custom, one-page, dark, brutalist
*/

/* ============================================================
   RESET BASE + TOKENS
============================================================ */
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;scroll-padding-top:88px}
body{
  --bg:#EBEBEB;
  --surface:#F8F8F8;
  --dark1:#111111;
  --dark2:#1E1E1E;
  --primary:#729BBA;
  --primary-dark:#4F7391;
  --text:#111111;
  --text-soft:#5E6873;
  --text-on-dark:#E8E8E8;
  --border:#D4D4D4;
  --border-dark:rgba(232,232,232,.15);
  --grid:rgba(0,0,0,.06);
  --mono:ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace;
  --sans:ui-sans-serif, system-ui, -apple-system, "Segoe UI", Roboto, Helvetica, Arial;
  --display:'Kanit', var(--sans);

  background:var(--bg);
  color:var(--text);
  font-family:var(--sans);
  line-height:1.35;
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
}
img{max-width:100%;height:auto;display:block}
a{color:inherit;text-decoration:none}
button{font:inherit;color:inherit;background:none;border:none;cursor:pointer}
::selection{background:var(--primary);color:#fff}

/* admin bar di WP se loggato: lascia esistere, non rompere layout */
body.admin-bar{margin-top:0 !important}

.heading-gradient{
  background:linear-gradient(180deg,#646973 0%,#BBCCD7 100%);
  -webkit-background-clip:text;
  -webkit-text-fill-color:transparent;
  background-clip:text;
}
.about .heading-gradient{
  background:none;
  -webkit-text-fill-color:var(--text);
  color:var(--text);
}

.gridlines{
  pointer-events:none;
  position:fixed;
  inset:0;
  background:
    linear-gradient(to right,var(--grid) 0,var(--grid) 1px,transparent 1px,transparent 8.3333%),
    linear-gradient(to bottom,var(--grid) 0,var(--grid) 1px,transparent 1px,transparent 12.5%);
  opacity:.18;
  mix-blend-mode:multiply;
  z-index:1;
}

.mono,.eyebrow,.kicker,.tag,.nav a,.small,.hero-side li,.service-desc,.about-copy{
  font-family:var(--mono);
  text-transform:uppercase;
  letter-spacing:.06em;
}
.eyebrow,.kicker{font-size:12px;line-height:1.2;opacity:.82;letter-spacing:.1em}
.kicker{display:inline-flex;align-items:center;gap:8px}
.kicker::before{content:"";width:28px;height:1px;background:currentColor;opacity:.7}

/* ========== HERO ========== */
.hero{
  position:relative;
  min-height:100vh;
  min-height:100svh;
  display:flex;
  flex-direction:column;
  background:var(--dark1);
  color:var(--text-on-dark);
  overflow:hidden;
}
.hero-nav{display:flex;justify-content:space-between;align-items:center;padding:28px 32px 0;gap:16px;flex-wrap:wrap;position:relative;z-index:5}
.hero-nav .brand{font-family:var(--display);font-weight:900;letter-spacing:-.05em;font-size:22px;color:var(--text-on-dark);text-transform:uppercase}
.hero-nav-links{display:flex;gap:clamp(16px,3vw,40px);flex-wrap:wrap}
.hero-nav-links a{color:var(--text-on-dark);font-family:var(--mono);text-transform:uppercase;letter-spacing:.15em;font-size:11px;transition:color .2s;padding:6px 0;opacity:.75}
.hero-nav-links a:hover{opacity:1;color:var(--primary)}
.hero-tag{font-family:var(--mono);font-size:11px;letter-spacing:.15em;text-transform:uppercase;color:var(--primary);opacity:.9}
.hero-heading-wrap{padding:0 32px;margin-top:clamp(24px,5vh,52px);position:relative;z-index:3}
.hero h1{display:block;visibility:visible;opacity:1;font-family:var(--display);font-weight:900;text-transform:uppercase;letter-spacing:-.045em;line-height:.86;white-space:normal;width:min(100%,1420px);max-width:15ch;font-size:clamp(54px,10.8vw,166px)}
.hero-spacer{flex:1}
.hero-portrait{position:absolute;left:50%;transform:translateX(-50%);bottom:0;z-index:2;width:clamp(320px,55vw,820px);aspect-ratio:980/590;pointer-events:none}
.hero-portrait-inner{width:100%;height:100%;will-change:transform;transition:transform .6s ease-in-out}
.hero-portrait-inner picture{width:100%;height:100%;display:block}
.hero-portrait-inner img{width:100%;height:100%;object-fit:contain;object-position:center bottom;display:block}
.hero-portrait.is-active .hero-portrait-inner{transition:transform .3s ease-out}
.hero-bottom{position:relative;z-index:3;display:flex;justify-content:space-between;align-items:flex-end;gap:20px;padding:0 32px 40px}
.hero-tagline{max-width:280px;font-family:var(--mono);text-transform:uppercase;letter-spacing:.1em;line-height:1.5;font-size:clamp(11px,1.1vw,14px);color:var(--text-on-dark);opacity:.75}
.btn-contact{display:inline-flex;align-items:center;gap:10px;padding:14px 28px;background:transparent;color:var(--text-on-dark);font-family:var(--mono);text-transform:uppercase;letter-spacing:.18em;font-size:12px;font-weight:700;border-radius:999px;border:1.5px solid var(--primary);transition:background .25s ease,color .25s ease,transform .2s ease;white-space:nowrap}
.btn-contact:hover{background:var(--primary);color:#fff;transform:translateY(-2px)}
.btn-contact .arrow{display:inline-block;transition:transform .25s ease}
.btn-contact:hover .arrow{transform:translate(3px,-3px)}

/* ========== MARQUEE ========== */
.img-slot{width:100%;height:100%;border:2px dashed rgba(215,226,234,.35);background:repeating-linear-gradient(45deg,rgba(215,226,234,.04) 0,rgba(215,226,234,.04) 12px,transparent 12px,transparent 24px);display:flex;align-items:flex-end;justify-content:flex-start;padding:16px;position:relative}
.img-slot::before{content:"IMAGE SLOT";font-family:var(--mono);font-size:10px;letter-spacing:.2em;color:rgba(255,255,255,.3)}
.img-slot[data-label]::before{content:attr(data-label)}
.marquee{background:#1A1A1A;padding:100px 0;overflow:hidden;position:relative}
.marquee-row{display:flex;gap:14px;will-change:transform;margin-bottom:14px}
.marquee-row:last-child{margin-bottom:0}
.marquee-tile{flex:0 0 auto;width:clamp(260px,28vw,420px);aspect-ratio:16/10;border-radius:12px;overflow:hidden;background:#2A2A2A;border:1px solid rgba(255,255,255,.08);position:relative;isolation:isolate;margin:0}
.marquee-tile.is-portrait{width:clamp(220px,22vw,340px);aspect-ratio:4/5}
.marquee-tile.is-wide{width:clamp(360px,36vw,560px);aspect-ratio:21/9}
.marquee-tile img{width:100%;height:100%;object-fit:cover;object-position:center;display:block;transform:scale(1.015);filter:saturate(.92) contrast(1.05) brightness(.9);transition:transform .9s cubic-bezier(.22,1,.36,1),filter .9s cubic-bezier(.22,1,.36,1)}
.marquee-tile:hover img{transform:scale(1.06);filter:saturate(1) contrast(1.08) brightness(.96)}
.marquee-tile::after{content:"";position:absolute;inset:0;pointer-events:none;background:linear-gradient(to bottom,rgba(0,0,0,.02),rgba(0,0,0,.42));z-index:1}
.marquee-caption{position:absolute;left:16px;bottom:14px;z-index:2;display:flex;gap:10px;align-items:center;font-family:var(--mono);text-transform:uppercase;letter-spacing:.16em;font-size:10px;color:rgba(255,255,255,.72)}
.marquee-caption::before{content:"";width:18px;height:1px;background:currentColor;opacity:.7}

/* ========== ABOUT ========== */
.about{position:relative;background:var(--surface);color:var(--text);min-height:100vh;display:flex;flex-direction:column;justify-content:center;align-items:center;padding:140px 24px 120px;overflow:hidden}
.about-inner{width:100%;max-width:780px;margin:0 auto;display:flex;flex-direction:column;align-items:center;position:relative;z-index:2}
.about h2{font-family:var(--display);font-weight:900;text-transform:uppercase;letter-spacing:-.04em;line-height:.9;text-align:center;font-size:clamp(56px,12vw,180px);margin-bottom:36px}
.about-text{width:100%;max-width:620px;text-align:center;font-family:var(--mono);text-transform:uppercase;letter-spacing:.06em;line-height:1.7;font-size:clamp(13px,1.3vw,17px);margin-bottom:40px;color:var(--text);word-wrap:break-word}
.about-text .ch{display:inline;transition:opacity .15s linear;opacity:.18}
.about-text .ch.is-on{opacity:1}
.corner-deco{position:absolute;width:clamp(60px,9vw,130px);height:clamp(60px,9vw,130px);pointer-events:none;opacity:.4;z-index:1}
.corner-deco svg{width:100%;height:100%}
.corner-tl{top:8%;left:5%}
.corner-tr{top:8%;right:5%}
.corner-bl{bottom:10%;left:5%}
.corner-br{bottom:10%;right:5%}

/* ========== SERVICES (sticky stacking) ========== */
.services{background:var(--dark1);color:var(--text-on-dark);padding:clamp(90px,10vw,140px) 32px 90px;position:relative;z-index:2;overflow:clip}
.services::before{content:"";position:absolute;inset:0;pointer-events:none;background:radial-gradient(circle at 18% 12%,rgba(115,155,186,.12),transparent 28%),linear-gradient(to right,rgba(255,255,255,.035) 1px,transparent 1px),linear-gradient(to bottom,rgba(255,255,255,.03) 1px,transparent 1px);background-size:auto,8.333% 100%,100% 12.5%;opacity:.55}
.services-header{position:relative;z-index:2;max-width:1240px;margin:0 auto clamp(72px,9vw,120px);display:grid;grid-template-columns:minmax(0,1fr) minmax(320px,.58fr);gap:clamp(40px,6vw,90px);align-items:end}
.services-eyebrow{font-family:var(--mono);text-transform:uppercase;letter-spacing:.2em;font-size:11px;color:var(--primary);display:inline-flex;align-items:center;gap:10px;margin-bottom:18px}
.services-eyebrow::before{content:"";width:28px;height:1px;background:currentColor}
.services h2{font-family:var(--display);font-weight:900;text-transform:uppercase;letter-spacing:-.045em;line-height:.88;font-size:clamp(58px,11vw,164px);max-width:9ch;background:linear-gradient(180deg,#646973 0%,#BBCCD7 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.services-intro{font-family:var(--mono);text-transform:uppercase;letter-spacing:.06em;line-height:1.7;font-size:clamp(11px,1vw,13px);color:rgba(232,232,232,.72);max-width:56ch}
.service-list{position:relative;z-index:2;max-width:1240px;margin:0 auto}
.service-item{position:sticky;top:72px;min-height:clamp(420px,70vh,680px);display:grid;grid-template-columns:minmax(180px,.38fr) minmax(0,1.2fr);gap:clamp(40px,7vw,120px);align-items:center;margin:0 auto 36px;padding:clamp(42px,5vw,72px);background:#171717;border:1px solid rgba(115,155,186,.24);border-radius:28px;box-shadow:0 24px 80px rgba(0,0,0,.28);transform-origin:top center;will-change:transform;overflow:hidden}
.service-item::before{content:"";position:absolute;inset:0;pointer-events:none;background:linear-gradient(to right,rgba(255,255,255,.035) 1px,transparent 1px),linear-gradient(to bottom,rgba(255,255,255,.03) 1px,transparent 1px);background-size:8.333% 100%,100% 12.5%;opacity:.4}
.service-num{position:relative;z-index:2;font-family:var(--display);font-weight:900;letter-spacing:-.06em;line-height:.78;font-size:clamp(96px,14vw,220px);color:var(--primary);opacity:.95;align-self:flex-start}
.service-body{position:relative;z-index:2;max-width:920px;display:flex;flex-direction:column;justify-content:center;gap:24px}
.service-name{font-family:var(--display);font-weight:900;text-transform:uppercase;letter-spacing:-.05em;line-height:.88;font-size:clamp(56px,8vw,132px);margin-bottom:0;max-width:10ch;color:var(--text-on-dark)}
.service-desc{font-family:var(--mono);text-transform:uppercase;letter-spacing:.06em;font-size:clamp(12px,1vw,14px);line-height:1.95;max-width:62ch;color:rgba(232,232,232,.72);padding-left:4px}

/* ========== PROJECTS ========== */
.projects-wrap{background:var(--surface);color:var(--text);position:relative;z-index:3;padding:clamp(90px,10vw,150px) 32px;overflow:hidden}
.projects-wrap::before{content:"";position:absolute;inset:0;pointer-events:none;background:radial-gradient(circle at 15% 10%,rgba(115,155,186,.14),transparent 28%),linear-gradient(to right,rgba(0,0,0,.035) 1px,transparent 1px),linear-gradient(to bottom,rgba(0,0,0,.035) 1px,transparent 1px);background-size:auto,8.333% 100%,100% 12.5%;opacity:.55}
.projects-header{position:relative;z-index:2;max-width:1240px;margin:0 auto clamp(80px,10vw,130px);display:grid;grid-template-columns:minmax(0,1.2fr) minmax(320px,.55fr);gap:clamp(60px,8vw,120px);align-items:end}
.projects-eyebrow{font-family:var(--mono);text-transform:uppercase;letter-spacing:.2em;font-size:11px;color:var(--primary);display:inline-flex;align-items:center;gap:10px;margin-bottom:18px}
.projects-eyebrow::before{content:"";width:28px;height:1px;background:currentColor}
.projects-title{font-family:var(--display);font-weight:900;text-transform:uppercase;letter-spacing:-.065em;line-height:.8;font-size:clamp(68px,11vw,184px);max-width:5.8ch;color:var(--text);word-break:keep-all}
.projects-intro{font-family:var(--mono);text-transform:uppercase;letter-spacing:.055em;line-height:1.9;font-size:clamp(11px,1vw,13px);color:var(--text-soft);max-width:42ch;align-self:end;padding-bottom:14px}
.project-list{position:relative;z-index:2;max-width:1240px;margin:0 auto;display:grid;gap:clamp(70px,9vw,130px)}
.project-card{display:grid;grid-template-columns:minmax(210px,.52fr) minmax(0,1.48fr);gap:clamp(40px,6vw,90px);align-items:start;padding-top:clamp(42px,5vw,70px);border-top:1px solid var(--border)}
.project-aside{position:sticky;top:96px}
.project-num{display:block;font-family:var(--display);font-weight:900;letter-spacing:-.045em;line-height:.82;font-size:clamp(64px,8vw,120px);color:var(--primary);margin-bottom:18px}
.project-meta{display:grid;gap:12px;font-family:var(--mono);text-transform:uppercase;letter-spacing:.11em;font-size:9px;color:var(--text-soft)}
.project-meta strong{display:block;color:var(--text);font-family:var(--display);font-size:clamp(14px,1.2vw,18px);line-height:1.05;letter-spacing:.01em;margin-top:4px;font-weight:700}
.project-main{min-width:0}
.project-head{display:grid;grid-template-columns:1fr auto;gap:28px;align-items:start;margin-bottom:clamp(36px,5vw,60px)}
.project-cat{font-family:var(--mono);text-transform:uppercase;letter-spacing:.16em;font-size:11px;color:var(--primary);margin-bottom:10px}
.project-name{font-family:var(--display);font-weight:900;text-transform:uppercase;letter-spacing:-.055em;line-height:.82;font-size:clamp(64px,8vw,140px);max-width:9ch}
.project-lead{margin-top:22px;max-width:60ch;font-family:var(--mono);text-transform:uppercase;letter-spacing:.055em;line-height:1.9;font-size:clamp(11px,1vw,13px);color:var(--text-soft)}
.btn-live{display:inline-flex;align-items:center;gap:8px;padding:11px 18px;border:1.5px solid var(--text);color:var(--text);border-radius:999px;font-family:var(--mono);text-transform:uppercase;letter-spacing:.16em;font-size:10px;font-weight:700;transition:background .25s,color .25s,border-color .25s,letter-spacing .25s;white-space:nowrap}
.btn-live:hover{background:var(--primary);color:#fff;border-color:var(--primary);letter-spacing:.21em}
.project-images{display:grid;grid-template-columns:minmax(260px,.78fr) minmax(420px,1.22fr);gap:18px;align-items:stretch;margin-bottom:clamp(44px,6vw,72px)}
.project-col-1{display:grid;grid-template-rows:auto auto;gap:18px}
.project-img{width:100%;border-radius:clamp(18px,2vw,30px);overflow:hidden;background:#111;position:relative;border:1px solid rgba(0,0,0,.08);box-shadow:0 10px 40px rgba(0,0,0,.06);isolation:isolate}
.project-img img{width:100%;height:100%;object-fit:cover;object-position:top center;display:block;transform:scale(1.005);transition:transform .9s cubic-bezier(.22,1,.36,1),filter .9s cubic-bezier(.22,1,.36,1);filter:saturate(.96) contrast(1.02)}
.project-card:hover .project-img img{transform:scale(1.04)}
.project-img.medium{aspect-ratio:16/10}
.project-img.tall{aspect-ratio:16/12}
.project-img.full{aspect-ratio:16/10}
.project-img .img-slot{border:none;border-radius:inherit;height:100%;background:linear-gradient(135deg,rgba(255,255,255,.035),transparent),repeating-linear-gradient(45deg,rgba(255,255,255,.035) 0,rgba(255,255,255,.035) 12px,transparent 12px,transparent 24px),#181818}
.project-img .img-slot::before{color:rgba(255,255,255,.24);left:18px;bottom:16px;position:absolute}
.project-img::after{content:"";position:absolute;inset:0;pointer-events:none;background:linear-gradient(to bottom,rgba(0,0,0,0),rgba(0,0,0,.08));opacity:.65}
.project-case{display:grid;gap:0;border-top:1px solid var(--border)}
.project-case-row{display:grid;grid-template-columns:140px 1fr;gap:clamp(24px,3vw,44px);padding:28px 0;border-bottom:1px solid var(--border)}
.project-case-row h3{font-family:var(--mono);text-transform:uppercase;letter-spacing:.16em;font-size:10px;color:var(--primary);padding-top:5px;font-weight:700}
.project-case-row p{color:var(--text-soft);font-size:clamp(14px,1.15vw,17px);line-height:1.7;max-width:68ch}
.project-stack{list-style:none;display:flex;flex-wrap:wrap;gap:8px;padding:0;margin:0}
.project-stack li{border:1px solid var(--border);border-radius:999px;padding:8px 12px;color:var(--text);font-family:var(--mono);text-transform:uppercase;letter-spacing:.09em;font-size:10px;background:rgba(255,255,255,.42)}

/* ========== CONTACT ========== */
.contact{background:var(--dark2);color:var(--text-on-dark);padding:140px 32px;position:relative;z-index:4}
.contact-inner{max-width:1100px;margin:0 auto}
.contact h2{font-family:var(--display);font-weight:900;text-transform:uppercase;letter-spacing:-.04em;line-height:.9;font-size:clamp(56px,10vw,140px);margin-bottom:24px;margin-top:14px;color:var(--text-on-dark)}
.contact-copy{max-width:60ch;font-family:var(--mono);text-transform:uppercase;letter-spacing:.06em;font-size:12px;line-height:1.7;margin-bottom:60px;color:var(--text-on-dark);opacity:.75}
.contact-links{display:grid;grid-template-columns:1fr 1fr;gap:20px}
.contact-link{border:1px solid var(--border-dark);padding:24px;display:flex;align-items:center;justify-content:space-between;gap:20px;transition:background .2s,border-color .2s;color:var(--text-on-dark)}
.contact-link:hover{background:rgba(255,255,255,.06);border-color:var(--primary)}
.contact-link-label{font-family:var(--mono);text-transform:uppercase;letter-spacing:.12em;font-size:11px;color:var(--primary)}
.contact-link-value{font-family:var(--display);font-weight:700;font-size:clamp(16px,2vw,24px);letter-spacing:-.02em}
.contact-link-arrow{font-family:var(--display);font-size:24px}

/* ========== FOOTER ========== */
.xedniv-footer{background:var(--dark2);color:var(--text-on-dark);border-top:1px solid rgba(255,255,255,.06);padding:28px 32px;font-family:var(--mono);text-transform:uppercase;letter-spacing:.06em;font-size:12px;opacity:.65}
.footer-inner{max-width:1100px;margin:0 auto;display:flex;justify-content:space-between;flex-wrap:wrap;gap:14px}

.fade-in{opacity:0;transform:translateY(30px);transition:opacity .8s cubic-bezier(.25,.1,.25,1),transform .8s cubic-bezier(.25,.1,.25,1)}
.fade-in.is-visible{opacity:1;transform:translateY(0)}

@media (prefers-reduced-motion: reduce){
  *{animation:none !important;transition:none !important}
  .fade-in{opacity:1;transform:none}
  .about-text .ch{opacity:1}
}

/* ============================================================
   MOBILE
============================================================ */
@media (max-width:768px){
  .gridlines{opacity:.12}
  .hero{min-height:100svh;height:auto;padding-bottom:24px}
  .hero-nav{padding:18px 18px 0}
  .hero-nav-links{display:none}
  .hero-tag{font-size:10px}
  .hero-heading-wrap{padding:0 18px;margin-top:44px}
  .hero h1{font-size:clamp(48px,18vw,86px);max-width:10ch;line-height:.88}
  .hero-portrait{width:min(86vw,420px);top:52%;bottom:auto;transform:translate(-50%,-50%);opacity:.55}
  .hero-bottom{padding:120px 18px 0;flex-direction:column;align-items:flex-start;gap:18px}
  .hero-tagline{max-width:34ch;font-size:10px;line-height:1.6}
  .btn-contact{padding:12px 18px;font-size:10px;letter-spacing:.13em}

  .marquee{padding:42px 0}
  .marquee-row{gap:10px;margin-bottom:10px}
  .marquee-tile,.marquee-tile.is-wide,.marquee-tile.is-portrait{width:72vw;aspect-ratio:16/10;border-radius:12px}
  .marquee-caption{left:12px;bottom:10px;font-size:8px;letter-spacing:.12em}

  .about{min-height:100svh;padding:88px 18px 92px}
  .about h2{font-size:clamp(56px,18vw,86px);margin-bottom:24px}
  .about-text{font-size:11px;line-height:1.75;margin-bottom:28px;max-width:36ch}
  .corner-deco{opacity:.22;width:64px;height:64px}

  .services{padding:76px 16px 70px;overflow:hidden}
  .services-header{display:block;margin-bottom:34px}
  .services h2{max-width:none;font-size:clamp(48px,17vw,82px);line-height:.9;margin-bottom:18px}
  .services-intro{max-width:34ch;font-size:10px;line-height:1.7}
  .service-list{display:grid;gap:14px}
  .service-item{position:relative !important;top:auto !important;min-height:auto !important;display:grid;grid-template-columns:1fr;gap:20px;margin:0 !important;padding:24px 20px 28px;border-radius:18px;transform:none !important}
  .service-num{font-size:64px;line-height:.8;align-self:auto}
  .service-name{font-size:clamp(34px,12vw,58px);max-width:8.5ch;line-height:.9}
  .service-desc{font-size:10px;line-height:1.75;padding-left:0;max-width:34ch}

  .projects-wrap{padding:78px 16px 90px}
  .projects-header{display:block;margin-bottom:44px}
  .projects-title{max-width:none;font-size:clamp(58px,18vw,96px);line-height:.82;margin-bottom:22px}
  .projects-intro{max-width:34ch;padding-bottom:0;font-size:10px;line-height:1.75}
  .project-list{gap:76px}
  .project-card{display:grid;grid-template-columns:1fr;gap:26px;padding-top:34px}
  .project-aside{position:relative;top:auto}
  .project-num{font-size:68px;margin-bottom:14px}
  .project-meta{gap:10px;font-size:8px}
  .project-meta strong{font-size:15px}
  .project-head{display:grid;grid-template-columns:1fr;gap:18px;margin-bottom:26px}
  .project-name{font-size:clamp(44px,15vw,76px);max-width:8.5ch;line-height:.86}
  .project-lead{margin-top:14px;max-width:34ch;font-size:10px;line-height:1.75}
  .project-head .btn-live{justify-self:start}
  .project-images{grid-template-columns:1fr;gap:12px;margin-bottom:32px}
  .project-col-1{gap:12px}
  .project-img,.project-img.medium,.project-img.tall,.project-img.full{aspect-ratio:16/11;border-radius:16px}
  .project-case-row{grid-template-columns:1fr;gap:8px;padding:18px 0}
  .project-case-row p{font-size:13px;line-height:1.65}
  .project-stack{gap:7px}
  .project-stack li{font-size:9px;padding:7px 10px}

  .contact{padding:86px 18px}
  .contact h2{font-size:clamp(48px,15vw,82px)}
  .contact-copy{font-size:10px;line-height:1.75}
  .contact-links{grid-template-columns:1fr}
  .contact-link{padding:18px;align-items:flex-start}
  .contact-link-value{font-size:18px;word-break:break-word}
  .footer-inner{flex-direction:column;align-items:flex-start}
}
