/* ============================================================
   strenity — Sofia Street Trinity
   2026 responsive system: fluid rem scales, intrinsic grids,
   container queries, dynamic viewport units, a11y baked in.
   Scales cleanly from ~360px phones up to 2560px+ ultra-wide.
   Body copy is lorem ipsum placeholder text (to be replaced).
   ============================================================ */

:root{
  /* ---------- palette ---------- */
  --teal-900:#153B48;   /* footer / navbar / cards (deepest) */
  --teal-800:#1b4554;
  --teal-700:#244854;   /* intro section base */
  --teal-600:#2a5666;
  --teal-accent:#215467;/* lighter inner box / leaf fill */
  --cream:#E8E3DD;      /* cream nav card */
  --paper:#D9D6D1;      /* light page background */
  --paper-2:#cdccc7;
  --ink:#16242b;
  --on-teal:#dcd8d1;
  --on-teal-dim:rgba(220,216,209,.62);
  --line:rgba(220,216,209,.28);

  /* ---------- layout ---------- */
  --maxw:1440px;            /* content cap (raised on ultra-wide, see bottom) */
  --bleed-max:2560px;       /* stop full-bleed sections stretching on 4K */
  --topbar-h:90px;

  /* ---------- fluid SPACE scale (px @360 -> @2560), Utopia method ---------- */
  --space-3xs: clamp(0.25rem, 0.230rem + 0.091vw, 0.375rem); /*  4 ->  6 */
  --space-2xs: clamp(0.5rem,  0.459rem + 0.182vw, 0.75rem);  /*  8 -> 12 */
  --space-xs:  clamp(0.75rem, 0.689rem + 0.273vw, 1.125rem); /* 12 -> 18 */
  --space-s:   clamp(1rem,    0.918rem + 0.364vw, 1.5rem);   /* 16 -> 24 */
  --space-m:   clamp(1.5rem,  1.377rem + 0.545vw, 2.25rem);  /* 24 -> 36 */
  --space-l:   clamp(2rem,    1.836rem + 0.727vw, 3rem);     /* 32 -> 48 */
  --space-xl:  clamp(3rem,    2.755rem + 1.091vw, 4.5rem);   /* 48 -> 72 */
  --space-2xl: clamp(4rem,    3.673rem + 1.455vw, 6rem);     /* 64 -> 96 */
  --space-3xl: clamp(6rem,    5.509rem + 2.182vw, 9rem);     /* 96 ->144 */

  /* section gutter (replaces old --pad, but keeps the name) */
  --pad: clamp(1.25rem, -0.18rem + 6.36vw, 10rem);           /* 20 ->160 */

  /* ---------- fluid TYPE scale (px @360 -> @2560), rem floors so it
       respects user zoom AND keeps growing toward 2K ---------- */
  --step--1: clamp(0.8125rem, 0.792rem + 0.091vw, 0.9375rem); /* 13 -> 15 */
  --step-0:  clamp(0.875rem,  0.834rem + 0.182vw, 1.125rem);  /* 14 -> 18  body */
  --step-1:  clamp(1.0625rem, 0.981rem + 0.364vw, 1.5625rem); /* 17 -> 25 */
  --step-2:  clamp(1.25rem,   1.127rem + 0.545vw, 2rem);      /* 20 -> 32 */
  --step-3:  clamp(1.5rem,    1.336rem + 0.727vw, 2.5rem);    /* 24 -> 40 */
  --step-4:  clamp(1.75rem,   1.505rem + 1.091vw, 3.25rem);   /* 28 -> 52 */
  --step-5:  clamp(2.125rem,  1.798rem + 1.455vw, 4rem);      /* 34 -> 64 */

  --mono:"JetBrains Mono",ui-monospace,"SFMono-Regular",Menlo,Consolas,monospace;
}

*{box-sizing:border-box}
html{
  scroll-behavior:smooth;
  /* clip (not hidden) so decorative negative-offset leaves can't cause
     horizontal scroll, without killing position:sticky */
  overflow-x:clip;
}
body{
  margin:0;
  font-family:var(--mono);
  font-weight:300;
  font-size:var(--step-0);
  color:var(--ink);
  background:var(--paper);
  -webkit-font-smoothing:antialiased;
  line-height:1.7;
  overflow-x:clip;
}
img{display:block;max-width:100%}
a{color:inherit;text-decoration:none}

.wrap{
  width:min(var(--maxw), 100% - 2 * var(--pad));
  margin-inline:auto;
}

p{margin:0 0 1em;font-size:var(--step-0);letter-spacing:.02em;text-wrap:pretty;max-width:72ch}
.muted{color:var(--on-teal-dim)}

h1,h2,h3,h4{text-wrap:balance}

/* ---------- accessibility helpers ---------- */
.skip-link{
  position:absolute;left:-9999px;top:0;z-index:100;
  background:var(--cream);color:var(--teal-900);
  padding:12px 18px;font-weight:600;letter-spacing:.04em;
}
.skip-link:focus{left:8px;top:8px;outline:2px solid var(--teal-900)}

:focus-visible{
  outline:2px solid var(--cream);
  outline-offset:3px;
  border-radius:2px;
}
:focus:not(:focus-visible){outline:none}

/* ---------- TOP NAVBAR (inner pages) ---------- */
.topbar{
  background:var(--teal-900);
  color:var(--on-teal);
  position:sticky;top:0;z-index:50;
  padding-top:env(safe-area-inset-top);
}
.topbar .inner{
  max-width:var(--maxw);margin:0 auto;
  height:var(--topbar-h);
  display:flex;align-items:center;justify-content:space-between;
  padding-inline:max(var(--pad), env(safe-area-inset-left)) max(var(--pad), env(safe-area-inset-right));
}
.brand-mark{display:flex;align-items:center;gap:14px}
.brand-mark img{height:clamp(30px,3vw,42px);width:auto}
.wordmark{
  font-family:"Fredoka",var(--mono);font-weight:600;
  font-size:clamp(1.5rem,1.36rem + .6vw,2.125rem);letter-spacing:.01em;color:var(--cream);
}
.primary-nav{display:contents}
.nav-links{display:flex;gap:clamp(20px,3vw,52px);list-style:none;margin:0;padding:0}
.nav-links a{
  display:inline-block;
  font-size:clamp(.875rem,.82rem + .25vw,1.0625rem);font-weight:300;letter-spacing:.14em;
  color:var(--on-teal);padding-bottom:4px;border-bottom:1px solid transparent;
  transition:border-color .25s,color .25s;
}
.nav-links a:hover{color:#fff}
.nav-links a.active,.nav-links a[aria-current="page"]{border-color:var(--on-teal)}

.nav-toggle{display:none}

/* ---------- LANDING : split header ---------- */
.hero-split{
  display:grid;
  /* cream stays 38.2% until it hits ~528px, then the photo takes all extra
     width so the panel never becomes an empty field on ultra-wide */
  grid-template-columns:min(38.2%, 33rem) 1fr;
  min-height:100vh;   /* fallback for old browsers */
  min-height:100svh;  /* fill the visible viewport — no empty band below the fold */
}
.hero-card{
  background:var(--cream);
  padding:clamp(2rem,3.4vw,3.25rem) clamp(2.1rem,3.6vw,3.6rem);
  display:flex;flex-direction:column;
}
.hero-card .mark{width:clamp(3rem,4.2vw,4.5rem);height:auto}
.hero-nav{display:flex;flex-direction:column;gap:clamp(20px,2.6vw,40px);margin:auto 0}
.hero-nav a{
  font-size:clamp(1.125rem,.85rem + 1vw,1.875rem);letter-spacing:.05em;color:var(--teal-900);font-weight:400;
  width:max-content;padding-block:6px;border-bottom:1px solid transparent;transition:border-color .25s;
}
.hero-nav a:hover{border-color:var(--teal-900)}
.hero-photo{
  background:#3a3530 center/cover no-repeat;
  background-image:url("assets/hero.jpg");
}
/* mobile-only immersive overlay parts — hidden on the desktop split */
.hero-bar,.hero-menu,.hero-brand{display:none}

/* ---------- LANDING : intro atmospheric section (CSS text boxes) ---------- */
.intro{
  position:relative;width:100%;max-width:var(--bleed-max);margin-inline:auto;color:var(--on-teal);
  container-type:inline-size;
  aspect-ratio:1440/1480;
  background:
    linear-gradient(rgba(11,27,34,.6),rgba(11,27,34,.6)) left/cover no-repeat,
    url("assets/intro_bg.jpg") left/cover no-repeat,
    #16323d;
}
.intro::after{
  content:"";position:absolute;inset:0;z-index:1;pointer-events:none;
  background:linear-gradient(180deg,
    rgba(20,52,63,.55) 0%,
    rgba(20,52,63,.12) 14%,
    rgba(20,52,63,.05) 42%,
    rgba(20,52,63,.32) 66%,
    rgba(21,59,72,.88) 86%,
    var(--teal-900) 100%);
}
.intro .itxt{
  position:absolute;z-index:2;display:flex;flex-direction:column;justify-content:center;
  font-size:clamp(8px,1.12cqw,16px);line-height:1.95;letter-spacing:.04em;text-align:justify;
  overflow-wrap:break-word;
}
.intro .itxt p{margin:0;max-width:none}
.intro .one{left:0;top:9%;width:68.4%;height:24%;padding:0 5.4% 0 6.7%;
  background:rgba(22,52,62,.93)}
.intro .two{left:35.8%;top:56%;width:64.2%;height:27%;padding:0 6.8% 0 4.2%;
  background:rgba(33,84,103,.9)}
.intro .two .more{
  align-self:flex-end;margin-top:1.5em;font-size:.92em;letter-spacing:.18em;
  color:var(--on-teal);border-bottom:1px solid var(--on-teal);padding-bottom:2px;
}
.intro .two .more:hover{color:#fff}

/* On phones the fixed aspect-ratio + absolute boxes get cramped, so stop
   fighting it: let the section grow with content and stack the boxes.
   NOTE: must be a media query, not @container — an element can't be styled
   by a container query on itself (.intro defines the container). */
@media (max-width:900px){
  /* stack naturally; don't force full height or spread the boxes apart */
  .intro{aspect-ratio:auto;display:flex;flex-direction:column;gap:var(--space-l);padding:var(--space-2xl) var(--pad)}
  /* solid panels so text never sits on the atmospheric gradient */
  .intro .itxt{
    position:static;width:auto;height:auto;max-width:none;
    font-size:var(--step-0);line-height:1.8;padding:var(--space-m);
    text-align:left;   /* justified mono over-spaces on narrow screens */
  }
  .intro .one,.intro .two{left:auto;top:auto}
  .intro .one{background:var(--teal-900)}
  .intro .two{background:var(--teal-accent)}
  /* replace the foggy desktop fade with a uniform darken into the footer —
     no light middle band crossing the content */
  .intro::after{
    background:linear-gradient(180deg,
      rgba(20,52,63,.30) 0%,
      rgba(20,52,63,.55) 60%,
      var(--teal-900) 100%);
  }
}

/* ---------- generic page hero photo band ---------- */
.photo-band{height:clamp(13.75rem,26vw,23.75rem);background:#8b8b86 center/cover no-repeat}
.photo-band.about{background-image:url("assets/about_top.jpg")}
.photo-band.climber{background-image:url("assets/process_header.jpg");background-position:center 32%;height:clamp(10.6rem,20vw,18.75rem)}

/* ---------- ABOUT : text cards ---------- */
.about-body{
  position:relative;background:var(--paper);
  padding:var(--space-3xl) var(--pad);
  overflow:hidden;
}
.about-body::before{
  content:"";position:absolute;inset:0;z-index:0;
  /* Full-height overlay: statue photo as a band at the top, with a teal
     gradient that runs the WHOLE section — transparent over the statue,
     deepening to solid teal at the bottom so it meets the teal footer. */
  background:
    linear-gradient(180deg,
      rgba(21,59,72,.15),
      rgba(21,59,72,.15)),
    linear-gradient(180deg,
      transparent 0%,
      rgba(20,52,63,.125) 16%,
      rgba(20,52,63,.31) 38%,
      rgba(20,52,63,.5) 78%,
      var(--teal-900) 100%),
    url("assets/about_bg.jpg") center top/cover no-repeat;
  pointer-events:none;
}
.cards{display:flex;flex-direction:column;gap:var(--space-2xl);position:relative;z-index:2;max-width:var(--maxw);margin-inline:auto}
.tcard{
  /* ~10% transparent so the statue banner shows through; raise/lower the
     alpha to taste (lower = more see-through) */
  background:rgba(21,59,72,.9);color:var(--on-teal);
  padding:clamp(2rem,3.4vw,3rem);max-width:min(48.75rem,100%);
  box-shadow:0 28px 50px -34px rgba(0,0,0,.45);
}
.tcard.right{margin-left:auto}
.tcard.left{margin-right:auto}
.tcard p{line-height:1.95;letter-spacing:.03em;font-size:var(--step-0)}
.tcard p:last-child{margin-bottom:0}
.about-body .leaf-bg{
  position:absolute;opacity:.85;z-index:1;pointer-events:none;filter:grayscale(.2);
}

/* ---------- GALLERY ---------- */
.gallery-hero{background:url("assets/gallery_top.jpg") center/cover no-repeat;height:clamp(10.6rem,22vw,18.75rem)}
.scallop{
  height:34px;background:var(--teal-900);
  -webkit-mask:radial-gradient(circle at 50% 0,#000 17px,transparent 18px) center top/40px 34px repeat-x;
          mask:radial-gradient(circle at 50% 0,#000 17px,transparent 18px) center top/40px 34px repeat-x;
}
.gallery-band{background:var(--teal-900);height:30px}
.gallery-section{
  position:relative;background:var(--paper);overflow:hidden;
  padding:clamp(1.25rem,3vw,2.5rem) var(--pad) var(--space-3xl);
}
.gallery-section::before{
  content:"";position:absolute;inset:0;z-index:0;
  background:url("assets/gallery_bg.jpg") center/cover no-repeat;
  opacity:.14;
}
.section-title{
  position:relative;z-index:1;
  text-align:center;font-weight:400;letter-spacing:.16em;
  color:var(--teal-900);font-size:var(--step-4);
  margin:var(--space-l) 0 var(--space-xl);
}
/* Breakpoint-free intrinsic grid: auto-fit + min() overflow guard.
   Columns adapt to the grid's own width — no media-query ladder needed. */
.grid{
  position:relative;z-index:2;max-width:var(--maxw);margin-inline:auto;
  display:grid;
  grid-template-columns:repeat(auto-fit, minmax(min(100%, 16rem), 1fr));
  gap:clamp(12px,1.5vw,22px);
}
.grid > *{min-width:0}
.grid figure{margin:0;aspect-ratio:1/1.05;overflow:hidden;background:#bcbbb6}
.grid figure button{display:block;width:100%;height:100%;margin:0;padding:0;border:0;background:none;cursor:zoom-in}
.grid img{width:100%;height:100%;object-fit:cover;transition:transform .5s ease}
.deco{position:absolute;z-index:1;pointer-events:none}
.deco.tl{top:-40px;left:-50px;width:230px;transform:rotate(8deg)}
.deco.tr{top:6%;right:-46px;width:150px;transform:rotate(-18deg)}
.deco.bl{bottom:8%;left:-40px;width:150px;transform:rotate(160deg)}
.deco.br{bottom:-30px;right:-30px;width:200px;transform:rotate(190deg)}

/* ---------- PROCESS ---------- */
.qr-panel{
  position:relative;background:var(--teal-700);color:var(--on-teal);overflow:hidden;
  padding:var(--space-2xl) var(--pad);
}
.qr-inner{
  position:relative;z-index:1;max-width:var(--maxw);margin:0 auto;
  display:flex;gap:clamp(30px,5vw,80px);align-items:center;justify-content:space-between;flex-wrap:wrap;
}
.qr-inner .qr-text{max-width:38.75rem;font-size:var(--step-1);line-height:1.5;letter-spacing:.02em;font-weight:300}
.qr-inner img{width:clamp(9.4rem,16vw,13.1rem);height:auto;flex:none;background:#fff;padding:6px}

.process-rows{
  position:relative;background:var(--paper);overflow:hidden;
  padding:var(--space-3xl) var(--pad);
  display:flex;flex-direction:column;gap:var(--space-2xl);
}
.srow{
  position:relative;z-index:2;max-width:var(--maxw);width:100%;margin-inline:auto;
  display:grid;grid-template-columns:minmax(0,1fr) minmax(0,1.05fr);
  gap:clamp(20px,3vw,48px);align-items:stretch;
}
.srow .art{
  position:relative;aspect-ratio:1/.92;overflow:hidden;background:#cdccc7;
  border:0;padding:0;margin:0;cursor:pointer;display:block;width:100%;
}
.srow .art img{width:100%;height:100%;object-fit:cover;transition:transform .5s ease}
.srow .art .zoom{
  position:absolute;right:14px;bottom:14px;width:38px;height:38px;border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  background:rgba(21,59,72,.82);color:var(--cream);font-size:24px;font-weight:300;line-height:1;
  opacity:1;transform:scale(1);transition:opacity .25s,transform .25s;
}

/* ---------- LIGHTBOX ---------- */
.lightbox{
  position:fixed;inset:0;z-index:200;display:none;
  align-items:center;justify-content:center;
  background:rgba(13,30,37,.92);padding:clamp(20px,5vw,70px);
  opacity:0;transition:opacity .25s;
}
.lightbox.open{display:flex;opacity:1}
.lightbox img{max-width:100%;max-height:100%;object-fit:contain;box-shadow:0 30px 80px -20px rgba(0,0,0,.7)}
.lb-close{
  position:absolute;top:max(22px,env(safe-area-inset-top));right:max(30px,env(safe-area-inset-right));
  background:none;border:0;cursor:pointer;
  color:var(--cream);font-size:46px;line-height:1;font-family:var(--mono);
}
.lb-close:hover{color:#fff}
.srow .panel{
  background:var(--teal-900);color:var(--on-teal);
  padding:clamp(2rem,4vw,3.75rem);
  display:flex;flex-direction:column;justify-content:center;align-items:center;text-align:center;
}
.srow .panel h3{
  font-weight:400;font-size:var(--step-2);letter-spacing:.08em;margin:0 0 6px;color:var(--cream);
}
.srow .panel .sub{font-size:var(--step--1);letter-spacing:.14em;color:var(--on-teal-dim);margin-bottom:24px}
.srow .panel p{max-width:44ch;line-height:1.9;letter-spacing:.03em;font-size:var(--step-0)}
.srow .panel p:last-child{margin-bottom:0}
.process-rows .leaf-bg{position:absolute;z-index:1;pointer-events:none;opacity:.85}

/* ---------- FOOTER ---------- */
.site-footer{background:var(--teal-900);color:var(--on-teal);padding:var(--space-2xl) var(--pad)}
.foot{
  max-width:var(--maxw);margin:0 auto;
  display:grid;grid-template-columns:auto 1px 1.1fr 1.5fr;gap:clamp(28px,4vw,64px);align-items:start;
}
.foot .logo img{width:clamp(6.25rem,9vw,8.75rem);height:auto}
.foot .divider{background:var(--line);width:1px;height:100%;min-height:160px}
.foot h4{font-weight:400;font-size:var(--step-0);letter-spacing:.04em;color:var(--cream);margin:0 0 20px}
.foot ul{list-style:none;margin:0 0 30px;padding:0;display:flex;flex-direction:column;gap:12px}
.foot ul a{display:inline-block;font-size:var(--step--1);letter-spacing:.08em;color:var(--on-teal-dim)}
.foot ul a:hover{color:var(--on-teal)}
.foot .contacts a.ig{color:var(--on-teal);border-bottom:1px solid var(--on-teal);width:max-content}
.foot .contacts .mail{font-size:var(--step--1);letter-spacing:.04em;color:var(--on-teal-dim);margin-top:12px}
.foot .identity{text-align:center}
.foot .identity h3{font-weight:400;font-size:var(--step-3);letter-spacing:.04em;color:var(--cream);margin:0 0 6px}
.foot .identity .tag{font-size:var(--step--1);letter-spacing:.12em;color:var(--on-teal-dim);margin-bottom:26px}
.foot .identity p{font-size:var(--step--1);line-height:1.95;letter-spacing:.03em;color:var(--on-teal-dim);max-width:60ch;margin:0 auto 26px}
.foot .identity .rule{width:230px;height:1px;background:var(--line);margin:0 auto 22px}
.foot .identity .year{font-size:var(--step--1);letter-spacing:.16em;color:var(--on-teal-dim)}

/* ============================================================
   RESPONSIVE — a small, content-driven set of page-level breaks.
   (Components scale fluidly / via container query above.)
   ============================================================ */

/* tablet & nav collapse */
@media(max-width:900px){
  /* LANDING: immersive full-screen photo hero with overlay bar + drawer */
  .hero-split{grid-template-columns:1fr;min-height:auto}
  .hero-card{display:none}
  .hero-photo{
    position:relative;min-height:100svh;
    display:flex;flex-direction:column;
  }
  .hero-photo::after{
    content:"";position:absolute;inset:auto 0 0 0;height:46%;z-index:1;pointer-events:none;
    background:linear-gradient(0deg,rgba(13,30,37,.9),rgba(13,30,37,.32) 50%,transparent);
  }
  .hero-bar{
    display:flex;align-items:center;justify-content:space-between;position:relative;z-index:3;
    background:var(--teal-900);
    padding-block:max(14px,env(safe-area-inset-top)) 14px;
    padding-inline:max(var(--pad),env(safe-area-inset-left)) max(var(--pad),env(safe-area-inset-right));
  }
  .hero-bar .brand-mark{display:flex;align-items:center;gap:12px}
  .hero-bar .brand-mark img{height:30px;width:auto;filter:brightness(0) invert(1);opacity:.92}
  .hero-bar .wordmark{font-family:"Fredoka",var(--mono);font-weight:600;font-size:1.5rem;letter-spacing:.01em;color:var(--cream)}
  .hero-bar .nav-toggle{
    display:flex;flex-direction:column;gap:5px;background:none;border:0;cursor:pointer;
    min-width:44px;min-height:44px;align-items:center;justify-content:center;
  }
  .hero-bar .nav-toggle span{width:26px;height:2px;background:var(--cream)}
  .hero-menu{
    display:block;position:absolute;z-index:2;left:0;right:0;
    top:calc(env(safe-area-inset-top) + 62px);
    background:var(--teal-900);
    transform:translateY(-130%);transition:transform .3s;visibility:hidden;
  }
  .hero-menu.open{transform:translateY(0);visibility:visible}
  .hero-menu ul{list-style:none;margin:0;padding:8px 0}
  .hero-menu a{display:block;padding:16px var(--pad);min-height:48px;color:var(--on-teal);letter-spacing:.14em;font-size:1.0625rem;transition:color .25s}
  .hero-menu a:hover{color:#fff}
  .hero-brand{
    display:flex;flex-direction:column;gap:8px;position:relative;z-index:3;margin-top:auto;
    padding-inline:max(var(--pad),env(safe-area-inset-left)) max(var(--pad),env(safe-area-inset-right));
    padding-bottom:max(44px,env(safe-area-inset-bottom));
  }
  .hero-wordmark{font-family:"Fredoka",var(--mono);font-weight:600;color:var(--cream);font-size:clamp(2.75rem,16vw,4.5rem);line-height:.95;letter-spacing:.01em}
  .hero-tag{font-size:var(--step-0);letter-spacing:.14em;color:var(--on-teal);max-width:24ch}

  .srow{grid-template-columns:1fr}
  .srow .panel{padding:40px 28px}
  .foot{grid-template-columns:1fr;gap:40px}
  .foot .divider{display:none}
  .foot .identity{text-align:left}
  .foot .identity p,.foot .identity .rule{margin-left:0}

  /* match index: bar is NOT sticky on mobile, it scrolls away with the page */
  .topbar{position:relative}
  .topbar .inner{height:auto;padding-block:max(14px,env(safe-area-inset-top)) 14px}

  /* mobile nav drawer */
  .nav-links{
    position:fixed;inset:calc(62px + env(safe-area-inset-top)) 0 auto 0;z-index:60;
    background:var(--teal-900);
    flex-direction:column;gap:0;padding:8px 0;padding-bottom:env(safe-area-inset-bottom);
    transform:translateY(-120%);transition:transform .3s;
    visibility:hidden;
  }
  .nav-links.open{transform:translateY(0);visibility:visible}
  .nav-links a{display:block;padding:16px var(--pad);min-height:48px}
  .nav-toggle{
    display:flex;flex-direction:column;gap:5px;background:none;border:0;cursor:pointer;
    min-width:44px;min-height:44px;align-items:center;justify-content:center;
  }
  .nav-toggle span{width:26px;height:2px;background:var(--on-teal)}
  body.nav-locked{position:fixed;left:0;right:0;width:100%;overflow:hidden}
}

/* large phone */
@media(max-width:600px){
  .qr-inner{flex-direction:column;align-items:flex-start}
  .deco.tl{width:140px;top:-24px;left:-30px}
}

/* ---------- ULTRA-WIDE (2K / 4K): grow the canvas, not the type ---------- */
@media(min-width:1800px){
  :root{--maxw:1680px}
}
@media(min-width:2400px){
  :root{--maxw:1840px}
}

/* ---------- pointer / hover capability ---------- */
/* Only apply hover affordances on true hover+fine-pointer devices so touch
   users don't get stuck-hover states. */
@media (hover:hover) and (pointer:fine){
  .grid figure:hover img{transform:scale(1.05)}
  .srow .art:hover img{transform:scale(1.04)}
  .srow .art .zoom{opacity:0;transform:scale(.8)}
  .srow .art:hover .zoom,.srow .art:focus-visible .zoom{opacity:1;transform:scale(1)}
}

/* ---------- user preferences ---------- */
@media (prefers-reduced-motion:reduce){
  html{scroll-behavior:auto}
  *,*::before,*::after{
    animation-duration:.001ms !important;
    animation-iteration-count:1 !important;
    transition-duration:.001ms !important;
  }
}
@media (prefers-contrast:more){
  :root{
    --on-teal-dim:rgba(220,216,209,.92);
    --line:rgba(220,216,209,.6);
  }
  .nav-links a,.hero-nav a{text-decoration:underline}
}
