/* ===========================================================
   Art?  —  styles
   One committed direction: a warm-paper gallery. The interface stays
   quiet; the artwork supplies the color. Discipline everywhere, the
   painterly video hero is the one loud move.

   Voices:  serif (Fraunces) = display + the word "Art?"
            sans  (Space Grotesk) = tracked labels, nav, body
            mono  (Space Mono) = metadata (medium, year, handle)
=========================================================== */

*{ box-sizing:border-box; margin:0; padding:0; }
/* the `hidden` attribute must always win — author display rules (e.g. .mine-gate{display:grid})
   otherwise override the UA stylesheet and leave hidden panels visible */
[hidden]{ display:none !important; }
img{ display:block; max-width:100%; }
button{ font:inherit; color:inherit; background:none; border:none; cursor:pointer; }
input,textarea{ font:inherit; }
a{ color:inherit; text-decoration:none; cursor:pointer; }

:root{
  /* warm paper, never #fff / #000 */
  --paper:#f4f1ea; --paper-2:#ece7db; --panel:#faf7f0;
  --ink:#1a1714; --ink-soft:#6b6258; --faint:#a59d8f;
  --line:#ddd6c7; --line-strong:#c9c0ad;
  --accent:#c2553d;            /* the one confident accent: terracotta */
  --accent-ink:#faf7f0;

  --serif:'Fraunces',Georgia,'Times New Roman',serif;
  --sans:'Space Grotesk',system-ui,-apple-system,sans-serif;
  --mono:'Space Mono','SFMono-Regular',ui-monospace,monospace;

  --ease:cubic-bezier(.16,1,.3,1);     /* the premium settle curve */
  --ease-soft:cubic-bezier(.23,1,.32,1);

  --mx:clamp(1.25rem,8vw,9rem);        /* oversized outer margin */
}

html{ scroll-behavior:smooth; }
/* if Lenis is active it owns scrolling; let it */
html.lenis,html.lenis body{ height:auto; }
.lenis.lenis-smooth{ scroll-behavior:auto; }

body{
  background:var(--paper); color:var(--ink);
  font-family:var(--sans); font-weight:400; font-size:1.0625rem; line-height:1.6;
  letter-spacing:-.011em; -webkit-font-smoothing:antialiased; overflow-x:hidden; min-height:100vh;
}
::selection{ background:var(--accent); color:var(--accent-ink); }
:focus-visible{ outline:2px solid var(--accent); outline-offset:3px; }

/* the italic "?" that carries the brand */
.mark span,.nav-logo span,.footer-big span,.about-title span,.modal-mark span{
  color:var(--accent); font-style:italic;
}

/* ---------- grain overlay: the handmade tell ---------- */
.grain{ position:fixed; inset:0; width:100%; height:100%; pointer-events:none;
  z-index:9999; opacity:.05; mix-blend-mode:multiply; }

/* ---------- shared type helpers ---------- */
.label{ font-family:var(--sans); font-size:.72rem; font-weight:500;
  text-transform:uppercase; letter-spacing:.22em; color:var(--ink-soft); }
.meta{ font-family:var(--mono); font-size:.8rem; letter-spacing:0; color:var(--ink-soft); }
.display{ font-family:var(--serif); font-weight:300; line-height:.92; letter-spacing:-.03em;
  font-optical-sizing:auto; }

/* ---------- scroll reveal (the one motion system) ---------- */
.reveal{ opacity:0; transform:translateY(26px);
  transition:opacity 1s var(--ease), transform 1s var(--ease);
  transition-delay:var(--d,0ms); }
.reveal.is-in{ opacity:1; transform:none; }

/* ---------- buttons (quiet, editorial) ---------- */
.btn{ display:inline-flex; align-items:center; justify-content:center; gap:.5rem;
  padding:.85rem 1.4rem; font-family:var(--sans); font-size:.8rem; font-weight:500;
  text-transform:uppercase; letter-spacing:.14em; border:1px solid transparent;
  transition:background .4s var(--ease), color .4s var(--ease), border-color .4s var(--ease); }
.btn--accent{ background:var(--ink); color:var(--paper); }
.btn--accent:hover{ background:var(--accent); }
.btn--outline{ background:transparent; color:var(--ink); border-color:var(--line-strong); }
.btn--outline:hover{ border-color:var(--ink); }
.btn--blue{ background:var(--accent); color:var(--accent-ink); }   /* legacy hook, folded into accent */
.btn-block{ width:100%; }

/* ---------- nav ---------- */
.nav{ position:fixed; top:0; left:0; right:0; z-index:60; display:flex; align-items:center;
  justify-content:space-between; padding:1.4rem var(--mx);
  background:linear-gradient(var(--paper),rgba(244,241,234,0)); mix-blend-mode:normal; }
.nav-logo{ font-family:var(--serif); font-size:1.6rem; font-weight:400; letter-spacing:-.02em; line-height:1; }
.nav-links{ display:flex; align-items:center; gap:clamp(1rem,2.4vw,2rem); }
.nav-links a{ font-family:var(--sans); font-size:.72rem; font-weight:500; letter-spacing:.2em;
  text-transform:uppercase; color:var(--ink-soft); transition:color .3s; }
.nav-links a:hover{ color:var(--ink); }
.nav-auth{ display:flex; align-items:center; gap:.8rem; }
.nav-auth .nav-user{ font-family:var(--mono); font-size:.78rem; color:var(--ink-soft); }
.nav-auth .pill{ font-family:var(--sans); font-size:.68rem; font-weight:500; letter-spacing:.18em;
  text-transform:uppercase; border:1px solid var(--line-strong); padding:.5rem .9rem; transition:border-color .3s; }
.nav-auth .pill:hover{ border-color:var(--ink); }

/* hero nav sits on dark video -> lighten it */
body.at-hero .nav{ background:linear-gradient(rgba(10,8,5,.5),rgba(10,8,5,0)); }
body.at-hero .nav-logo{ color:#f4ecde; }
body.at-hero .nav-links a{ color:rgba(244,236,222,.72); }
body.at-hero .nav-links a:hover{ color:#fff; }
body.at-hero .nav-auth .nav-user{ color:rgba(244,236,222,.72); }
body.at-hero .nav-auth .pill{ color:#f4ecde; border-color:rgba(244,236,222,.4); }
body.at-hero .nav-auth .pill:hover{ border-color:#f4ecde; }

/* ---------- views ---------- */
.view{ display:none; }
.view.is-active{ display:block; }

/* ===================================================================
   HERO — full-bleed painterly video, graded + grained, type as a
   film title in the lower third. Off-center, sparse, editorial.
=================================================================== */
.hero{ position:relative; min-height:100svh; overflow:hidden; display:flex;
  flex-direction:column; justify-content:flex-end; padding:0 var(--mx) clamp(3rem,9vh,7rem); }
.hero-video{ position:absolute; inset:0; width:100%; height:100%; object-fit:cover; z-index:0;
  pointer-events:none; filter:brightness(.62) saturate(.8) contrast(1.08); }
/* directional scrim ONLY where the type sits (lower-left), plus a fade into the paper below */
.hero-tint{ position:absolute; inset:0; z-index:1; pointer-events:none;
  background:
    linear-gradient(to top, rgba(12,8,4,.74) 0%, rgba(12,8,4,.34) 26%, rgba(12,8,4,0) 56%),
    linear-gradient(to right, rgba(12,8,4,.5) 0%, rgba(12,8,4,0) 52%),
    linear-gradient(to bottom, rgba(12,8,4,0) 80%, var(--paper) 100%); }
/* fine grain over the footage so it reads graded, not stock */
.hero-grain{ position:absolute; inset:0; z-index:2; pointer-events:none; opacity:.16; mix-blend-mode:overlay; }

.hero-inner{ position:relative; z-index:3; width:100%; max-width:58rem; color:#f4ecde; }
.hero-eyebrow{ font-family:var(--mono); font-size:.8rem; letter-spacing:.04em;
  color:rgba(244,236,222,.8); margin-bottom:1.2rem; }
.hero .mark{ font-family:var(--serif); font-weight:300; letter-spacing:-.04em; line-height:.86;
  font-size:clamp(5rem,20vw,17rem); }
.hero-line{ font-family:var(--serif); font-weight:300; font-style:italic;
  font-size:clamp(1.25rem,3.2vw,2.2rem); line-height:1.18; max-width:24ch; margin-top:1rem;
  color:rgba(244,236,222,.92); }

/* search as a thin underlined field, not a glassy pill */
.hero-search{ margin-top:2.4rem; max-width:30rem; }
.gooey-search{ position:relative; display:flex; align-items:center; gap:.8rem;
  border-bottom:1px solid rgba(244,236,222,.45); padding:.7rem .1rem;
  transition:border-color .4s var(--ease); }
.gooey-search:focus-within{ border-color:#f4ecde; }
.gs-icon{ display:flex; color:rgba(244,236,222,.7); flex:0 0 auto; }
.gs-icon svg{ width:1.1rem; height:1.1rem; }
.gs-input{ flex:1; background:none; border:none; outline:none; color:#f4ecde;
  font-family:var(--serif); font-style:italic; font-weight:300; font-size:clamp(1.1rem,2vw,1.5rem);
  caret-color:var(--accent); }
.gs-input::placeholder{ color:transparent; }
.gs-input::-webkit-search-cancel-button,.gs-input::-webkit-search-decoration{ -webkit-appearance:none; appearance:none; }
.gs-ghost{ position:absolute; left:1.9rem; top:50%; transform:translateY(-50%); display:flex; align-items:center;
  pointer-events:none; color:rgba(244,236,222,.6);
  font-family:var(--serif); font-style:italic; font-weight:300; font-size:clamp(1.1rem,2vw,1.5rem); }
.gs-ghost.is-hidden{ display:none; }
.gs-ghost-text{ white-space:pre; }
.gs-caret{ display:inline-block; width:2px; height:1.05em; margin-left:3px; background:var(--accent); }
.gs-caret.blink{ animation:caretBlink 1.05s steps(1,end) infinite; }
@keyframes caretBlink{ 50%{ opacity:0; } }

/* scroll cue */
.hero-cue{ position:absolute; left:50%; bottom:1.5rem; transform:translateX(-50%); z-index:3;
  font-family:var(--mono); font-size:.7rem; letter-spacing:.2em; text-transform:uppercase;
  color:rgba(244,236,222,.7); display:flex; flex-direction:column; align-items:center; gap:.5rem; }
.hero-cue i{ display:block; width:1px; height:2.4rem; background:linear-gradient(rgba(244,236,222,.7),rgba(244,236,222,0));
  animation:cueDrop 2.4s var(--ease) infinite; transform-origin:top; }
@keyframes cueDrop{ 0%{ transform:scaleY(0); opacity:0; } 30%{ opacity:1; } 100%{ transform:scaleY(1); opacity:0; } }

/* ===================================================================
   DISCOVER — section head + the calm gallery
=================================================================== */
.section-head{ display:flex; align-items:flex-end; justify-content:space-between; gap:1rem;
  flex-wrap:wrap; padding:clamp(3.5rem,7vw,6rem) var(--mx) 1.4rem; }
.section-head::after{ content:""; }
.section-title{ font-family:var(--serif); font-weight:300; font-size:clamp(2rem,5.5vw,4.5rem);
  letter-spacing:-.03em; line-height:.95; }
.section-meta{ font-family:var(--mono); font-size:.82rem; color:var(--ink-soft); }
.gallery-wrap{ padding:1.5rem var(--mx) clamp(4rem,9vw,8rem); border-top:1px solid var(--line); margin:0 var(--mx);
  padding-left:0; padding-right:0; }

/* honest masonry, committed. no shadows, no rounded dashboard cards, no lift. */
.gallery{ column-count:3; column-gap:clamp(1.5rem,3vw,3.5rem); }
.card{ break-inside:avoid; margin-bottom:clamp(2.5rem,4vw,4.5rem); cursor:pointer; display:block; }
.card-art{ position:relative; overflow:hidden; background:var(--paper-2); }
.card-art img{ width:100%; height:100%; object-fit:cover;
  filter:grayscale(.16) contrast(1.03) saturate(1.02); transform:scale(1.001);
  transition:filter .7s var(--ease-soft), transform 1.1s var(--ease); }
.card:hover .card-art img{ filter:grayscale(0) contrast(1.04) saturate(1.08); transform:scale(1.05); }
/* wall label (Zwirner): name roman / discipline · No. italic-grey */
.card-label{ padding:.9rem .1rem 0; }
.card-name{ display:block; font-family:var(--serif); font-weight:400; font-size:1.25rem;
  letter-spacing:-.01em; line-height:1.15; }
.card-meta{ display:block; font-family:var(--mono); font-size:.74rem; color:var(--ink-soft); margin-top:.35rem; }
.card-meta em{ font-style:italic; }

.gallery-empty{ padding:1rem 0 4rem; display:flex; flex-direction:column; align-items:flex-start; gap:1.4rem; }
.gallery-empty p{ font-family:var(--serif); font-weight:300; font-size:clamp(1.4rem,3vw,2.2rem);
  color:var(--ink-soft); max-width:22ch; line-height:1.2; }

/* ---------- footer ---------- */
.footer{ padding:clamp(4rem,8vw,7rem) var(--mx) 2.4rem; border-top:1px solid var(--line); }
.footer-big{ font-family:var(--serif); font-weight:300; font-size:clamp(5rem,22vw,18rem);
  line-height:.8; letter-spacing:-.05em; }
.footer-row{ display:flex; justify-content:space-between; gap:.6rem; flex-wrap:wrap; margin-top:1.4rem;
  font-family:var(--mono); font-size:.76rem; color:var(--ink-soft); }

/* ===================================================================
   PORTFOLIO — viewing room. big work, quiet tombstone label.
=================================================================== */
.view-portfolio{ padding:7rem var(--mx) 6rem; min-height:100vh; }
.back{ font-family:var(--sans); font-size:.7rem; font-weight:500; letter-spacing:.18em; text-transform:uppercase;
  color:var(--ink-soft); transition:color .3s; }
.back:hover{ color:var(--ink); }
.pf-hero{ display:grid; grid-template-columns:minmax(0,1.6fr) minmax(0,1fr); gap:clamp(2rem,5vw,5rem);
  align-items:end; margin:2.2rem 0 3.5rem; padding-bottom:2.6rem; border-bottom:1px solid var(--line); }
.pf-head{ min-width:0; display:flex; flex-direction:column; align-items:flex-start; order:-1; }
.pf-kicker{ font-family:var(--mono); font-size:.82rem; color:var(--ink-soft); margin-bottom:1.1rem; }
.pf-name{ font-family:var(--serif); font-weight:300; font-size:clamp(3rem,8vw,7.5rem);
  line-height:.9; letter-spacing:-.04em; margin-bottom:1.4rem; }
.pf-bio{ color:var(--ink-soft); font-size:clamp(1rem,1.5vw,1.2rem); line-height:1.6; max-width:46ch; }
.pf-contact{ display:flex; gap:1.4rem; flex-wrap:wrap; margin-top:1.6rem; font-family:var(--mono); font-size:.82rem; }
.pf-contact a{ border-bottom:1px solid var(--line-strong); padding-bottom:2px; transition:border-color .3s, color .3s; }
.pf-contact a:hover{ border-color:var(--accent); color:var(--accent); }
.pf-avatar{ aspect-ratio:4/5; overflow:hidden; background:var(--paper-2); }
.pf-avatar img{ width:100%; height:100%; object-fit:cover; filter:grayscale(.18); }
.pf-works{ column-count:2; column-gap:clamp(1.5rem,3vw,3rem); }
.pf-work{ break-inside:avoid; margin:0 0 clamp(1.5rem,3vw,3rem); overflow:hidden; background:var(--paper-2); cursor:pointer; }
.pf-work img{ width:100%; height:100%; object-fit:cover; filter:grayscale(.16);
  transition:filter .7s var(--ease-soft), transform 1.1s var(--ease); }
.pf-work:hover img{ filter:grayscale(0); transform:scale(1.04); }
.pf-empty{ color:var(--faint); font-family:var(--mono); font-size:.86rem; padding:.6rem 0; }

/* ---------- about / info page ---------- */
.about-page{ padding:9rem var(--mx) clamp(4rem,9vw,8rem); max-width:84rem; }
.about-intro{ margin-bottom:clamp(2.5rem,6vw,5rem); }
.about-kicker{ font-family:var(--sans); font-size:.72rem; font-weight:500; letter-spacing:.22em;
  text-transform:uppercase; color:var(--accent); margin-bottom:1.4rem; }
.about-title{ font-family:var(--serif); font-weight:300; font-size:clamp(3rem,11vw,9.5rem);
  line-height:.9; letter-spacing:-.04em; }
.about-cols{ display:grid; grid-template-columns:1.4fr 1fr; gap:clamp(1.6rem,4vw,4rem); margin-top:2.6rem; }
.about-cols p{ font-family:var(--serif); font-weight:300; font-size:clamp(1.2rem,1.9vw,1.6rem); line-height:1.5; }
.about-cols p:last-child{ font-family:var(--sans); font-size:clamp(1rem,1.4vw,1.15rem); line-height:1.65; color:var(--ink-soft); align-self:start; }

/* info blocks: tracked label left, body right, hairline rule between */
.about-block{ display:grid; grid-template-columns:13rem minmax(0,1fr); gap:clamp(1.4rem,5vw,5rem);
  padding:clamp(2.4rem,5vw,3.6rem) 0; border-top:1px solid var(--line); }
.about-label{ font-family:var(--sans); font-size:.72rem; font-weight:500; letter-spacing:.22em;
  text-transform:uppercase; color:var(--ink-soft); padding-top:.45rem; }
.about-block-body{ min-width:0; }
.about-h{ font-family:var(--serif); font-weight:300; font-size:clamp(1.6rem,3.4vw,2.6rem);
  line-height:1.12; letter-spacing:-.02em; max-width:22ch; }
.about-block-body > p{ color:var(--ink-soft); font-size:clamp(1rem,1.4vw,1.15rem); line-height:1.7;
  max-width:56ch; margin-top:1.1rem; }

/* help FAQ */
.about-faq{ display:flex; flex-direction:column; }
.faq-item{ padding:1.2rem 0; border-bottom:1px solid var(--line); }
.faq-item:first-child{ padding-top:0; }
.faq-item:last-child{ border-bottom:none; padding-bottom:0; }
.faq-item dt{ font-family:var(--serif); font-weight:400; font-size:clamp(1.1rem,1.8vw,1.35rem); letter-spacing:-.01em; }
.faq-item dd{ color:var(--ink-soft); font-size:clamp(.98rem,1.3vw,1.1rem); line-height:1.65; margin-top:.5rem; max-width:62ch; }

/* contact */
.about-contact-mail{ font-family:var(--mono); font-size:.92rem; margin-top:1.2rem; }
.about-contact-mail a{ border-bottom:1px solid var(--line-strong); padding-bottom:2px; transition:border-color .3s, color .3s; }
.about-contact-mail a:hover{ border-color:var(--accent); color:var(--accent); }
.about-contact-actions{ display:flex; gap:.8rem; flex-wrap:wrap; margin-top:1.8rem; }

/* ===================================================================
   MY PORTFOLIO — editor + live preview
=================================================================== */
.mine-gate{ min-height:100vh; display:grid; place-items:center; padding:8rem 1.5rem; text-align:center; }
.gate-inner{ max-width:38rem; }
.gate-inner h1{ font-family:var(--serif); font-weight:300; font-size:clamp(2.8rem,8vw,6rem);
  letter-spacing:-.04em; line-height:.92; }
.gate-inner p{ color:var(--ink-soft); font-size:1.1rem; line-height:1.6; margin-top:1.2rem; }
.gate-cta{ display:flex; gap:.8rem; justify-content:center; margin-top:2rem; flex-wrap:wrap; }
.mine-wrap{ padding:7rem var(--mx) 6rem; }
.mine-title{ font-family:var(--serif); font-weight:300; font-size:clamp(2.6rem,7vw,6rem);
  letter-spacing:-.04em; line-height:.92; }
.mine-sub{ color:var(--ink-soft); font-size:1.05rem; margin-top:.9rem; max-width:46ch; }
.mine-grid{ display:grid; grid-template-columns:1.05fr .8fr; gap:clamp(2rem,4vw,4rem); margin-top:2.8rem; align-items:start; }
.field{ margin-bottom:1.2rem; }
.field-row{ display:grid; grid-template-columns:1fr 1fr; gap:1rem; }
.field label{ display:block; font-family:var(--sans); font-size:.68rem; font-weight:500; letter-spacing:.2em;
  text-transform:uppercase; color:var(--ink-soft); margin-bottom:.5rem; }
.field input,.field textarea{ width:100%; background:var(--panel); border:1px solid var(--line-strong); color:var(--ink);
  padding:.8rem .85rem; font-family:var(--sans); font-size:.98rem; resize:vertical; transition:border-color .3s; }
.field input:focus,.field textarea:focus{ border-color:var(--ink); outline:none; }
.field input::placeholder,.field textarea::placeholder{ color:var(--faint); }
.uploader{ border:1px dashed var(--line-strong); padding:2rem; text-align:center; color:var(--ink-soft); cursor:pointer; transition:border-color .3s; }
.uploader:hover{ border-color:var(--accent); }
.uploader-plus{ font-family:var(--serif); font-size:1.8rem; color:var(--accent); line-height:1; }
.uploader-main{ font-size:.9rem; margin-top:.5rem; }
.uploader-sub{ font-family:var(--mono); font-size:.76rem; color:var(--faint); margin-top:.4rem; }
.uploader-sub span{ text-decoration:underline; text-underline-offset:3px; cursor:pointer; }
.work-list{ display:grid; grid-template-columns:repeat(auto-fill,minmax(5.4rem,1fr)); gap:.6rem; margin-top:.9rem; }
.work-thumb{ position:relative; aspect-ratio:1; overflow:hidden; background:var(--paper-2); }
.work-thumb img{ width:100%; height:100%; object-fit:cover; }
.work-thumb button{ position:absolute; top:5px; right:5px; width:30px; height:30px; border-radius:50%;
  background:rgba(20,16,12,.7); color:#fff; font-size:17px; line-height:1; display:grid; place-items:center;
  transition:background .2s; }
.work-thumb button:hover{ background:rgba(158,51,32,.92); }
.editor-actions{ display:flex; gap:.7rem; flex-wrap:wrap; margin-top:.4rem; }
.save-note{ margin-top:1rem; font-family:var(--mono); font-size:.8rem; color:var(--accent); min-height:1em; }
.mine-preview{ position:sticky; top:7rem; }
.preview-label{ font-family:var(--sans); font-size:.68rem; font-weight:500; letter-spacing:.2em;
  text-transform:uppercase; color:var(--ink-soft); margin-bottom:.9rem; }
.preview-card{ background:var(--panel); border:1px solid var(--line); overflow:hidden; }
.preview-card .pc-cover{ aspect-ratio:4/3; overflow:hidden; background:var(--paper-2); }
.preview-card .pc-cover img{ width:100%; height:100%; object-fit:cover; }
.preview-card .pc-body{ padding:1.3rem; }
.preview-card .pc-name{ font-family:var(--serif); font-weight:400; font-size:1.4rem; line-height:1.1; }
.preview-card .pc-disc{ font-family:var(--mono); font-size:.76rem; color:var(--ink-soft); margin-top:.4rem; }
.preview-card .pc-bio{ color:var(--ink-soft); font-size:.92rem; line-height:1.6; margin-top:.8rem; }
.preview-card .pc-mini{ display:grid; grid-template-columns:repeat(3,1fr); gap:.3rem; margin-top:1rem; }
.preview-card .pc-mini > div{ aspect-ratio:1; overflow:hidden; background:var(--paper-2); }
.preview-card .pc-mini img{ width:100%; height:100%; object-fit:cover; }

/* ---------- modal ---------- */
.modal{ position:fixed; inset:0; z-index:90; display:grid; place-items:center; padding:1.25rem; }
.modal[hidden]{ display:none; }
.modal-scrim{ position:absolute; inset:0; background:rgba(20,16,12,.5); backdrop-filter:blur(5px); }
.modal-card{ position:relative; width:100%; max-width:26rem; background:var(--panel); border:1px solid var(--line);
  padding:2rem; animation:modalIn .55s var(--ease); }
@keyframes modalIn{ from{ opacity:0; transform:translateY(16px); } to{ opacity:1; transform:none; } }
.modal-close{ position:absolute; top:1rem; right:1rem; font-family:var(--sans); font-size:.64rem; font-weight:500;
  letter-spacing:.18em; text-transform:uppercase; color:var(--ink-soft); transition:color .3s; }
.modal-close:hover{ color:var(--ink); }
.modal-mark{ font-family:var(--serif); font-size:1.7rem; font-weight:400; margin-bottom:1rem; }
.modal-title{ font-family:var(--serif); font-weight:400; font-size:1.6rem; letter-spacing:-.02em; }
.modal-sub{ color:var(--ink-soft); font-size:.92rem; margin:.4rem 0 1.4rem; }
.modal-card .field{ margin-bottom:1rem; }
.auth-error{ color:#c0392b; font-family:var(--mono); font-size:.8rem; min-height:1em; margin-top:.7rem; }
.auth-toggle{ margin-top:1.1rem; font-family:var(--mono); font-size:.8rem; color:var(--ink-soft); text-align:center; }
.auth-toggle button{ color:var(--accent); text-decoration:underline; text-underline-offset:3px; }
.auth-note{ font-family:var(--mono); font-size:.82rem; line-height:1.55; color:var(--ink-soft); margin-top:.7rem; min-height:1em; }
.auth-note.is-good{ color:#5f7d4a; }

/* ---------- robustness: button states, spinner, confirm, dropzone ---------- */
.btn:disabled,.btn[disabled]{ opacity:.55; cursor:default; }
.is-loading{ pointer-events:none; }
.is-loading::after{ content:""; width:.85em; height:.85em; flex:0 0 auto;
  border:2px solid currentColor; border-top-color:transparent; border-radius:50%;
  display:inline-block; animation:spin .7s linear infinite; opacity:.85; }
@keyframes spin{ to{ transform:rotate(360deg); } }
.btn--danger{ background:#9e3320; color:#fff; }
.btn--danger:hover{ background:#86291a; }

.confirm-modal{ position:fixed; inset:0; z-index:100; display:grid; place-items:center; padding:1.25rem;
  opacity:0; transition:opacity .2s var(--ease); }
.confirm-modal.is-open{ opacity:1; }
.confirm-scrim{ position:absolute; inset:0; background:rgba(20,16,12,.5); backdrop-filter:blur(5px); }
.confirm-card{ position:relative; width:100%; max-width:23rem; background:var(--panel); border:1px solid var(--line);
  padding:1.7rem; transform:translateY(12px); transition:transform .2s var(--ease); }
.confirm-modal.is-open .confirm-card{ transform:none; }
.confirm-msg{ font-size:1rem; line-height:1.5; color:var(--ink); margin-bottom:1.3rem; }
.confirm-actions{ display:flex; gap:.6rem; justify-content:flex-end; }

.uploader.is-dragover{ border-color:var(--accent); border-style:solid; background:var(--paper-2); }
.uploader.is-busy{ pointer-events:none; opacity:.7; }

.feed-error,.gallery-error,.pf-error{ font-family:var(--mono); font-size:.86rem; color:var(--ink-soft);
  display:flex; flex-direction:column; align-items:center; gap:1rem; padding:1rem 0; }

/* ---------- lightbox ---------- */
.lightbox{ position:fixed; inset:0; z-index:95; background:rgba(16,12,9,.94); backdrop-filter:blur(8px);
  display:none; place-items:center; padding:6vh 6vw; }
.lightbox.is-open{ display:grid; }
.lightbox-close{ position:absolute; top:1.2rem; right:1.2rem; font-family:var(--sans); font-size:.66rem;
  font-weight:500; letter-spacing:.18em; text-transform:uppercase; color:rgba(244,236,222,.8); }
.lightbox-close:hover{ color:#fff; }
.lightbox-art img{ max-width:90vw; max-height:88vh; object-fit:contain; }

/* ---------- toast ---------- */
.toast{ position:fixed; left:50%; bottom:2rem; transform:translate(-50%,200%); z-index:99;
  background:var(--ink); color:var(--paper); padding:.8rem 1.4rem; font-family:var(--mono); font-size:.8rem;
  transition:transform .5s var(--ease); pointer-events:none; max-width:90vw; }
.toast.is-show{ transform:translate(-50%,0); }
.toast.is-error{ background:#9e3320; color:#fff; }

/* ---------- responsive ---------- */
@media (max-width:1000px){
  .gallery{ column-count:2; }
}
@media (max-width:860px){
  .pf-hero{ grid-template-columns:1fr; }
  .pf-avatar{ max-width:22rem; aspect-ratio:4/5; }
  .pf-works{ column-count:1; }
  .mine-grid{ grid-template-columns:1fr; }
  .mine-preview{ position:static; }
  .about-cols{ grid-template-columns:1fr; }
  /* info blocks stack: label sits above its body */
  .about-block{ grid-template-columns:1fr; gap:.9rem; }
  .about-label{ padding-top:0; color:var(--accent); }
}

/* ---------- tablet / phone nav + heads ---------- */
@media (max-width:720px){
  :root{ --mx:clamp(1.1rem,5.5vw,9rem); }
  /* clean two-row nav: logo on top, links beneath */
  .nav{ flex-wrap:wrap; row-gap:.5rem; padding:.85rem var(--mx); }
  .nav-logo{ font-size:1.35rem; flex:0 0 auto; }
  .nav-links{ flex:1 0 100%; justify-content:space-between; gap:.5rem; min-width:0; }
  .nav-links a{ font-size:.64rem; letter-spacing:.1em; }
  .nav-auth{ gap:.5rem; margin-left:auto; }
  .nav-auth .pill{ font-size:.6rem; letter-spacing:.1em; padding:.45rem .8rem; }
  .nav-auth .nav-user{ display:none; }   /* name still shown in the editor */

  /* section heads breathe by stacking */
  .section-head{ flex-direction:column; align-items:flex-start; gap:.4rem; }
  .section-head .section-meta{ font-size:.78rem; }
}

@media (max-width:560px){
  .gallery{ column-count:1; }
  .field-row{ grid-template-columns:1fr; }
  .hero{ padding-bottom:clamp(2.5rem,12vh,5rem); }
  .hero-line{ font-size:clamp(1.15rem,5vw,1.6rem); max-width:30ch; }
  .hero-eyebrow{ font-size:.74rem; }
  .pf-contact{ gap:1rem; }
  .footer-row{ gap:.4rem; }
}

/* very small phones: keep nav on one tidy line */
@media (max-width:380px){
  .nav-links a{ font-size:.56rem; letter-spacing:.06em; }
  .nav-logo{ font-size:1.2rem; }
}
@media (prefers-reduced-motion:reduce){
  *{ animation:none !important; }
  html{ scroll-behavior:auto; }
  .reveal{ opacity:1; transform:none; transition:none; }
  .card-art img,.pf-work img{ transition:filter .3s; }
}

/* ===================================================================
   SOCIAL LAYER — feed, post modal, likes, comments, follow, avatar.
   Same quiet warm-paper grammar: hairlines, no shadows, serif names,
   mono metadata, one terracotta accent. Artwork still supplies color.
=================================================================== */

/* small / ghost button variants */
.btn-sm{ padding:.6rem 1rem; font-size:.7rem; letter-spacing:.12em; }
.btn--ghost{ background:transparent; color:var(--ink-soft); border-color:transparent; }
.btn--ghost:hover{ color:var(--ink); }

/* shared like button (feed + post modal + portfolio overlay) */
.like-btn{ display:inline-flex; align-items:center; gap:.45rem; color:var(--ink-soft);
  font-family:var(--mono); font-size:.82rem; transition:color .3s var(--ease); }
.like-btn:hover{ color:var(--ink); }
.like-btn svg{ width:1.4rem; height:1.4rem; fill:none; stroke:currentColor; stroke-width:1.5;
  transition:fill .25s var(--ease), stroke .25s var(--ease), transform .25s var(--ease); }
.like-btn.is-liked{ color:var(--accent); }
.like-btn.is-liked svg{ fill:var(--accent); stroke:var(--accent); transform:scale(1.06); }
.cmt-btn{ display:inline-flex; align-items:center; gap:.45rem; color:var(--ink-soft);
  font-family:var(--mono); font-size:.82rem; transition:color .3s; }
.cmt-btn:hover{ color:var(--ink); }
.cmt-btn svg{ width:1.3rem; height:1.3rem; }

/* ---------- FEED ---------- */
.view-feed{ padding:6.5rem 0 6rem; min-height:100vh; }
.view-feed .section-head{ max-width:42rem; margin:0 auto; padding-left:0; padding-right:0; }
.feed-wrap{ max-width:42rem; margin:0 auto; padding:0 1.25rem; }
.feed{ display:flex; flex-direction:column; gap:clamp(2.6rem,5vw,4rem); }
.feed-card-head{ display:flex; align-items:center; gap:.7rem; padding-bottom:.9rem; cursor:pointer; }
.feed-avatar,.post-avatar,.cmt-avatar{ display:block; border-radius:50%; overflow:hidden;
  background:var(--paper-2); flex:0 0 auto; }
.feed-avatar{ width:2.5rem; height:2.5rem; }
.feed-avatar img,.post-avatar img,.cmt-avatar img{ width:100%; height:100%; object-fit:cover; filter:grayscale(.1); }
.feed-card-who{ display:flex; flex-direction:column; line-height:1.15; min-width:0; }
.feed-card-name{ font-family:var(--serif); font-weight:400; font-size:1.05rem; }
.feed-card-handle{ font-family:var(--mono); font-size:.74rem; color:var(--ink-soft); }
.feed-card-art{ overflow:hidden; background:var(--paper-2); cursor:pointer; }
.feed-card-art img{ width:100%; height:auto; object-fit:cover;
  filter:grayscale(.14) contrast(1.03); transition:filter .7s var(--ease-soft), transform 1.1s var(--ease); }
.feed-card-art:hover img{ filter:grayscale(0) saturate(1.06); transform:scale(1.02); }
.feed-card-foot{ padding-top:.9rem; }
.feed-card-bar{ display:flex; align-items:center; gap:1.4rem; }
.feed-caption{ margin-top:.7rem; font-size:.98rem; line-height:1.55; color:var(--ink); }
.feed-caption-name{ font-family:var(--serif); font-weight:400; }
.feed-empty{ text-align:center; padding:clamp(3rem,10vw,6rem) 1rem; display:flex; flex-direction:column;
  align-items:center; gap:1.4rem; }
.feed-empty p{ font-family:var(--serif); font-weight:300; font-size:clamp(1.3rem,3vw,1.9rem);
  color:var(--ink-soft); max-width:26ch; line-height:1.3; }

/* ---------- POST MODAL (inside the lightbox) ---------- */
.post-modal{ display:flex; width:100%; max-width:64rem; max-height:86vh; background:var(--panel);
  border:1px solid var(--line); overflow:hidden; }
.post-media{ flex:1 1 58%; min-width:0; background:#15110d; display:flex; align-items:center; justify-content:center; }
.post-media img{ width:100%; height:100%; max-height:86vh; object-fit:contain; }
.post-side{ flex:0 0 22rem; max-width:22rem; display:flex; flex-direction:column; min-height:0; }
.post-author{ display:flex; align-items:center; gap:.7rem; padding:1.1rem 1.2rem;
  border-bottom:1px solid var(--line); cursor:pointer; }
.post-avatar{ width:2.3rem; height:2.3rem; }
.post-author-text{ display:flex; flex-direction:column; line-height:1.15; min-width:0; }
.post-author-name{ font-family:var(--serif); font-weight:400; font-size:1.05rem; }
.post-author-handle{ font-family:var(--mono); font-size:.74rem; color:var(--ink-soft); }
.post-caption{ padding:1rem 1.2rem; border-bottom:1px solid var(--line); }
.post-title{ display:block; font-family:var(--serif); font-weight:400; font-size:1.1rem; margin-bottom:.3rem; }
.post-caption-text{ font-size:.95rem; line-height:1.55; color:var(--ink); }
.post-actions{ padding:.9rem 1.2rem; border-bottom:1px solid var(--line); }
.post-actions .like-btn{ font-size:.86rem; }
.post-comments{ flex:1 1 auto; overflow-y:auto; list-style:none; padding:.6rem 1.2rem; margin:0; min-height:4rem; }
.cmt{ display:flex; gap:.6rem; padding:.7rem 0; border-bottom:1px solid var(--line); }
.cmt:last-child{ border-bottom:none; }
.cmt-avatar{ width:1.9rem; height:1.9rem; margin-top:.1rem; }
.cmt-body{ min-width:0; flex:1; }
.cmt-meta{ display:flex; align-items:baseline; gap:.5rem; flex-wrap:wrap; }
.cmt-name{ font-family:var(--serif); font-weight:400; font-size:.95rem; }
.cmt-handle{ font-family:var(--mono); font-size:.7rem; color:var(--faint); }
.cmt-time{ font-family:var(--mono); font-size:.68rem; color:var(--faint); margin-left:auto; }
.cmt-text{ font-size:.92rem; line-height:1.5; margin-top:.2rem; word-wrap:break-word; }
.cmt-del{ font-family:var(--sans); font-size:.6rem; font-weight:500; letter-spacing:.12em; text-transform:uppercase;
  color:var(--faint); align-self:flex-start; transition:color .3s; }
.cmt-del:hover{ color:#9e3320; }
.cmt-empty,.cmt-loading{ font-family:var(--mono); font-size:.8rem; color:var(--faint); padding:.6rem 0; }
.post-comment-form{ display:flex; gap:.5rem; padding:.9rem 1.2rem; border-top:1px solid var(--line); }
.post-comment-form input{ flex:1; background:var(--paper); border:1px solid var(--line-strong); color:var(--ink);
  padding:.6rem .7rem; font-family:var(--sans); font-size:.9rem; transition:border-color .3s; }
.post-comment-form input:focus{ border-color:var(--ink); outline:none; }
.post-signin{ margin:1rem 1.2rem; padding:.7rem 1rem; border:1px solid var(--line-strong);
  font-family:var(--sans); font-size:.7rem; font-weight:500; letter-spacing:.14em; text-transform:uppercase;
  color:var(--ink-soft); transition:border-color .3s, color .3s; }
.post-signin:hover{ border-color:var(--ink); color:var(--ink); }

/* ---------- PORTFOLIO additions: follow + per-work stats ---------- */
.pf-actions{ margin-top:1.6rem; }
.follow-btn.is-following{ background:transparent; color:var(--ink); border-color:var(--line-strong); }
.follow-btn.is-following:hover{ border-color:var(--accent); color:var(--accent); }
.pf-work-meta{ position:absolute; left:0; right:0; bottom:0; display:flex; gap:1rem; padding:.6rem .7rem;
  background:linear-gradient(rgba(20,16,12,0),rgba(20,16,12,.62)); opacity:0; transition:opacity .35s var(--ease); }
.pf-work:hover .pf-work-meta{ opacity:1; }
.pf-stat{ display:inline-flex; align-items:center; gap:.35rem; font-family:var(--mono); font-size:.76rem; color:#f4ecde; }
.pf-stat svg{ width:.95rem; height:.95rem; fill:none; stroke:currentColor; stroke-width:1.6; }
.pf-stat.is-liked svg{ fill:var(--accent); stroke:var(--accent); }

/* ---------- EDITOR additions: avatar + handle hint + caption ---------- */
.field-avatar .avatar-edit{ display:flex; align-items:center; gap:1rem; }
.avatar-preview{ width:4.5rem; height:4.5rem; border-radius:50%; overflow:hidden; background:var(--paper-2);
  border:1px solid var(--line); flex:0 0 auto; display:grid; place-items:center; }
.avatar-preview img{ width:100%; height:100%; object-fit:cover; }
.avatar-empty{ font-family:var(--mono); font-size:.62rem; color:var(--faint); text-align:center; }
.avatar-actions{ display:flex; gap:.5rem; flex-wrap:wrap; }
.handle-hint{ display:block; font-family:var(--mono); font-size:.74rem; margin-top:.4rem; min-height:1em; color:var(--ink-soft); }
.handle-hint.ok{ color:#5f7d4a; }
.handle-hint.bad{ color:#9e3320; }
.work-meta-row{ margin-bottom:.9rem; }
.work-thumb .work-cap{ position:absolute; left:0; right:0; bottom:0; padding:.3rem .4rem;
  font-family:var(--mono); font-size:.58rem; color:#f4ecde; white-space:nowrap; overflow:hidden; text-overflow:ellipsis;
  background:linear-gradient(rgba(20,16,12,0),rgba(20,16,12,.72)); }

/* ---------- onboarding walkthrough ---------- */
.mine-onboard{ padding:7rem var(--mx) 6rem; min-height:100vh; }
.ob-wrap{ max-width:40rem; margin:0 auto; }
.ob-progress{ font-family:var(--mono); font-size:.76rem; letter-spacing:.04em; color:var(--ink-soft); margin-bottom:1.6rem; }
.ob-step{ display:none; }
.ob-step.is-active{ display:block; animation:obIn .5s var(--ease); }
@keyframes obIn{ from{ opacity:0; transform:translateY(12px); } to{ opacity:1; transform:none; } }
.ob-title{ font-family:var(--serif); font-weight:300; font-size:clamp(2.8rem,8vw,6rem); line-height:.92; letter-spacing:-.04em; }
.ob-head{ font-family:var(--serif); font-weight:300; font-size:clamp(2rem,5vw,3.2rem); line-height:1; letter-spacing:-.03em; margin-bottom:1.8rem; }
.ob-title span,.ob-head span{ color:var(--accent); font-style:italic; }
.ob-lead{ color:var(--ink-soft); font-size:clamp(1.05rem,1.6vw,1.25rem); line-height:1.6; margin-top:1.2rem; max-width:40ch; }
.ob-note{ font-family:var(--mono); font-size:.76rem; color:var(--faint); margin:-.2rem 0 .4rem; }
.ob-actions{ display:flex; gap:.7rem; flex-wrap:wrap; margin-top:2.2rem; }
.ob-skip{ display:block; margin:2.6rem auto 0; font-family:var(--mono); font-size:.78rem; color:var(--faint);
  text-decoration:underline; text-underline-offset:3px; transition:color .3s; }
.ob-skip:hover{ color:var(--ink); }

/* ---------- social responsive ---------- */
@media (max-width:860px){
  .lightbox{ padding:2vh 2vw; }
  .post-modal{ flex-direction:column; max-height:92vh; }
  .post-media{ flex:0 0 auto; max-height:46vh; }
  .post-media img{ max-height:46vh; }
  .post-side{ flex:1 1 auto; max-width:none; width:100%; }
  .post-comments{ max-height:30vh; }
}
