/* engraved-atlas shared styles — Jack Homer · A Sky of One Person */

:root{
  --paper:#fbf7eb;
  --paper2:#f5f1e6;
  --ink:#0a0a0a;
  --ink-soft:#3a3a3a;
  --ink-faint:#6a6a6a;
  --accent:#1b4a8a;
  --rule:rgba(10,10,10,.2);
}

*{margin:0;padding:0;box-sizing:border-box}
html,body{background:var(--paper2);color:var(--ink);font-family:'Cormorant Garamond',serif;line-height:1.45;font-size:16px}
body{min-height:100vh;padding:32px 20px 56px;
  background-image:
    radial-gradient(circle at 12% 18%, var(--ink) 0.6px, transparent 1px),
    radial-gradient(circle at 78% 32%, var(--ink) 0.4px, transparent 1px),
    radial-gradient(circle at 44% 71%, var(--ink) 0.5px, transparent 1px),
    radial-gradient(circle at 88% 84%, var(--ink) 0.4px, transparent 1px),
    radial-gradient(circle at 6% 88%, var(--ink) 0.5px, transparent 1px);
  background-size:420px 420px,520px 520px,360px 360px,480px 480px,380px 380px}

a{color:inherit}
a:focus-visible{outline:1px solid var(--accent);outline-offset:2px}
.sr-only,.listview{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0 0 0 0);white-space:nowrap;border:0}
/* skip-to-content link — visible only when focused */
.skip{position:fixed;left:8px;top:8px;z-index:100;background:var(--ink);color:var(--paper);padding:9px 16px;border-radius:4px;font-family:'IBM Plex Mono',monospace;font-size:12px;letter-spacing:.1em;text-decoration:none;transform:translateY(-160%);transition:transform .15s ease}
.skip:focus{transform:none}
/* Sky / List view toggle */
.viewtoggle{margin-top:12px;background:none;border:1px solid var(--rule);border-radius:999px;padding:5px 14px;font-family:'IBM Plex Mono',monospace;font-size:10px;letter-spacing:.16em;text-transform:uppercase;color:var(--ink-soft);cursor:pointer;transition:border-color .2s,color .2s}
.viewtoggle:hover,.viewtoggle:focus-visible{border-color:var(--accent);color:var(--accent)}
/* list mode: reveal the index, hide the chart */
body.listmode main.chart > .sky-wrap,body.listmode .preface,body.listmode .compass,body.listmode .comet,body.listmode .moonphase{display:none}
body.listmode .listview{position:static;width:auto;height:auto;margin:0;overflow:visible;clip:auto;white-space:normal;padding:8px 56px 36px;border:0}
.listview h2{font-family:'Cormorant Garamond',serif;font-style:italic;font-weight:500;font-size:26px;margin-bottom:6px}
.listview h3{font-family:'IBM Plex Mono',monospace;font-size:11px;letter-spacing:.22em;text-transform:uppercase;color:var(--ink-soft);margin:22px 0 8px;border-bottom:1px solid var(--rule);padding-bottom:6px}
.listview p{font-size:15px;line-height:1.6;margin-bottom:8px}
.listview .ix{list-style:none;padding:0;margin:0}
.listview .ix li{font-size:14.5px;line-height:1.55;padding:9px 0;border-top:1px solid var(--rule)}
.listview .ix li:first-child{border-top:0}
.listview a{color:var(--accent);text-decoration:underline}
.listview .ix-contact{margin-top:20px;font-family:'IBM Plex Mono',monospace;font-size:12px;letter-spacing:.04em}
@media (max-width:720px){ body.listmode .listview{padding:6px 18px 28px} }

/* T1 — laid-paper SVG noise (hidden filter referenced as background) */
.paper-noise{position:absolute;inset:0;opacity:.05;pointer-events:none;z-index:0}

/* chart frame — T2 Greek-key meander border */
.chart{max-width:1180px;margin:0 auto;background:var(--paper);border:1.5px solid var(--ink);position:relative;
  box-shadow:0 1px 0 var(--ink),0 2px 0 var(--ink),0 12px 36px rgba(0,0,0,.15)}
.chart::before{content:'';position:absolute;inset:0;background:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='420' height='420'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='2' seed='3' stitchTiles='stitch'/><feColorMatrix values='0 0 0 0 0  0 0 0 0 0  0 0 0 0 0  0 0 0 0.55 0'/></filter><rect width='420' height='420' filter='url(%23n)'/></svg>");opacity:.04;pointer-events:none;z-index:1}

/* meander border around outer chart frame */
.meander-frame{position:absolute;inset:8px;border:0;pointer-events:none;z-index:2}
.meander-frame .strip{position:absolute;background-repeat:repeat-x;background-size:auto 12px}
.meander-frame .top,.meander-frame .bottom{left:8px;right:8px;height:12px;background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='36' height='12' viewBox='0 0 36 12'><g fill='none' stroke='%230a0a0a' stroke-width='0.6'><path d='M0 11 L0 4 L6 4 L6 8 L12 8 L12 0 L24 0 L24 8 L30 8 L30 4 L36 4 L36 11'/></g></svg>")}
.meander-frame .top{top:0}
.meander-frame .bottom{bottom:0;transform:scaleY(-1)}
.meander-frame .left,.meander-frame .right{top:8px;bottom:8px;width:12px;background-size:12px auto;background-repeat:repeat-y;background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='12' height='36' viewBox='0 0 12 36'><g fill='none' stroke='%230a0a0a' stroke-width='0.6'><path d='M11 0 L4 0 L4 6 L8 6 L8 12 L0 12 L0 24 L8 24 L8 30 L4 30 L4 36 L11 36'/></g></svg>")}
.meander-frame .left{left:0}
.meander-frame .right{right:0;transform:scaleX(-1)}

/* corner fleurons (T2) — replaces L-brackets */
.corner{position:absolute;width:28px;height:28px;z-index:3;pointer-events:none}
.corner.tl{top:14px;left:14px}
.corner.tr{top:14px;right:14px;transform:scaleX(-1)}
.corner.bl{bottom:14px;left:14px;transform:scaleY(-1)}
.corner.br{bottom:14px;right:14px;transform:scale(-1,-1)}

/* nav (all pages) */
.nav{max-width:1180px;margin:0 auto 16px;display:flex;align-items:center;justify-content:space-between;font-family:'IBM Plex Mono',monospace;font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--ink);gap:16px;flex-wrap:wrap}
.nav .brand{font-family:'Cormorant Garamond',serif;font-style:italic;font-size:18px;letter-spacing:.02em;text-transform:none;text-decoration:none;white-space:nowrap}
.nav ul{display:flex;gap:18px;list-style:none;flex-wrap:wrap;justify-content:flex-end}
.nav a{text-decoration:none;color:var(--ink-faint);transition:color .2s;white-space:nowrap}
.nav a:hover,.nav a[aria-current]{color:var(--ink)}
.nav a[aria-current]{font-weight:500}
@media (max-width:720px){
  .nav{flex-direction:column;align-items:flex-start;gap:10px;font-size:10px;letter-spacing:.16em}
  .nav ul{gap:6px;width:100%;justify-content:space-between}
  .nav a{padding:8px 4px;display:inline-block}
}

/* honor a stronger-contrast preference: pull the faint small-text labels up to full ink */
@media (prefers-contrast: more){
  :root{--ink-faint:#2a2a2a;--ink-soft:#1a1a1a}
}

/* header (T2 plate-title ornaments) */
.header{padding:34px 56px 18px;border-bottom:1.5px solid var(--ink);display:grid;grid-template-columns:1fr auto 1fr;align-items:end;gap:30px;position:relative;z-index:4}
.header .l,.header .r{font-family:'IBM Plex Mono',monospace;font-size:10.5px;letter-spacing:.18em;text-transform:uppercase;line-height:1.7}
.header .r{text-align:right}
.header .l b,.header .r b{display:block;font-family:'Cormorant Garamond',serif;font-weight:700;font-size:13px;letter-spacing:.08em;margin-bottom:2px}
.header .c{text-align:center}
.header .c .orn{display:block;font-size:18px;letter-spacing:.6em;margin-bottom:6px;color:var(--ink);font-family:serif;line-height:1}
.header .c h1{font-weight:500;font-style:italic;font-size:46px;letter-spacing:.01em;line-height:1}
.header .c .sub{font-family:'IBM Plex Mono',monospace;font-size:10.5px;letter-spacing:.3em;text-transform:uppercase;margin-top:8px}
@media (max-width:720px){
  .header{padding:24px 22px 14px;grid-template-columns:1fr;gap:10px}
  .header .l,.header .r{text-align:center}
  .header .c h1{font-size:34px}
}

/* preface */
.preface{padding:14px 56px 16px;border-bottom:1px solid var(--ink);display:grid;grid-template-columns:1fr 380px;gap:30px;font-size:14px;line-height:1.55;align-items:start;position:relative;z-index:4}
.preface p{font-style:normal;color:#1a1a1a}
.preface .legend{font-family:'IBM Plex Mono',monospace;font-size:9.5px;letter-spacing:.12em;text-transform:uppercase;line-height:1.9;border-left:1px solid var(--ink);padding-left:18px}
.preface .legend b{font-family:'Cormorant Garamond',serif;font-size:12px;letter-spacing:.18em;display:block;margin-bottom:4px;font-weight:700}
.preface .legend .filled{width:8px;height:8px;border-radius:50%;background:var(--ink);display:inline-block;vertical-align:middle;margin:0 10px 0 3px}
.preface .legend .ring{width:8px;height:8px;border-radius:50%;background:var(--paper);box-shadow:0 0 0 1.5px var(--ink);display:inline-block;vertical-align:middle;margin:0 10px 0 3px}
.preface .legend .dash{display:inline-block;width:16px;border-top:1px dashed var(--accent);margin:0 8px 0 3px;vertical-align:middle}
.preface .legend .hint{display:block;margin-top:6px;font-family:'Cormorant Garamond',serif;font-style:italic;font-size:12.5px;letter-spacing:.04em;text-transform:none;color:var(--accent)}
@media (max-width:720px){
  .preface{padding:14px 22px 14px;grid-template-columns:1fr;gap:18px}
  .preface .legend{border-left:0;border-top:1px solid var(--ink);padding-left:0;padding-top:14px}
}

/* sky */
.sky-wrap{position:relative;margin:6px 56px 22px;border:1px solid var(--ink);background:var(--paper);overflow:hidden;touch-action:manipulation;z-index:4}
/* grid + background stars now render inside the SVG cam (see renderGrid) so they
   pan and zoom with the chart instead of staying frozen */
.graticule .grid-major{stroke:rgba(10,10,10,.045);stroke-width:.5}
.graticule .grid-minor{stroke:rgba(10,10,10,.022);stroke-width:.5}
.graticule .bgstar{fill:var(--ink);opacity:.2}

/* figure lines — soft round caps (no SVG filter: it triggered a Chromium
   bug that hid the OS mouse cursor over the chart) */
.cons .edge{stroke-linecap:round}

/* compass needle springs toward the cursor */
.compass .needle{transform-box:fill-box;transform-origin:50% 67%;transition:transform .5s cubic-bezier(.2,1.3,.3,1)}
/* comet → colophon */
.comet{position:absolute;right:14px;top:12px;width:26px;height:26px;padding:4px;border:0;background:none;cursor:pointer;color:var(--ink-faint);opacity:.45;transition:opacity .25s,color .25s;z-index:6}
.comet:hover,.comet:focus-visible{opacity:1;color:var(--accent)}
.comet svg{width:100%;height:100%;fill:none;stroke:currentColor;stroke-width:1.5;stroke-linecap:round}

/* Phase B — rare shooting star */
.shooting{position:absolute;width:88px;height:1px;pointer-events:none;z-index:3;opacity:0;
  background:linear-gradient(90deg, transparent, var(--ink));animation:shoot 1.5s ease-out forwards}
@keyframes shoot{0%{opacity:0;transform:translate(-24px,-16px) rotate(20deg) scaleX(.2)}14%{opacity:.5}100%{opacity:0;transform:translate(150px,52px) rotate(20deg) scaleX(1)}}

/* Phase E — moon-phase glyph + seasonal asterism */
.moonphase{position:absolute;left:14px;bottom:12px;width:24px;height:24px;z-index:6;opacity:.8}
.moonphase svg{width:100%;height:100%;overflow:visible}
.moon-lit{fill:var(--ink)} .moon-shadow{fill:var(--paper)} .moon-ring{fill:none;stroke:var(--ink);stroke-width:1}
.seasonal{opacity:.3}
.seasonal line{stroke:var(--ink);stroke-width:.5;opacity:.5}
.seasonal .sstar{fill:var(--ink);opacity:.6}
.seasonal .slabel{font-family:'IBM Plex Mono',monospace;font-size:7.5px;letter-spacing:.16em;text-transform:uppercase;fill:var(--ink-faint)}

/* Phase D — plate develops on first load */
@media (prefers-reduced-motion: no-preference){
  .chart{animation:develop 900ms ease both}
  #cam{animation:precipitate 1300ms ease both}
}
@keyframes develop{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}
@keyframes precipitate{0%,35%{opacity:0}100%{opacity:1}}
@media (prefers-reduced-motion: no-preference){
  .graticule .bgstar.tw{animation:twinkle var(--tw,3s) ease-in-out var(--td,0s) infinite}
}
@keyframes twinkle{0%,100%{opacity:.28}50%{opacity:.6}}
@media (max-width:720px){
  .sky-wrap{margin:4px 22px 14px}
  /* SVG text sizes are in viewBox user units. The SVG renders into a small
     mobile container, so user-unit text shrinks. Scale labels up for legibility. */
  .sky-svg .glabel{font-size:18px}
  .sky-svg .nlabel{font-size:18px}
  .sky-svg .clabel{font-size:28px}
  .sky-svg .csub{font-size:13px}
  .sky-svg .figure-label{font-size:16px}
  .ticks text{font-size:13px}
}

.sky-svg{display:block;width:100%;height:auto;position:relative;z-index:2;cursor:default}
.cam{transform-origin:0 0;transition:transform 800ms cubic-bezier(.25,.1,.25,1)}
@media (prefers-reduced-motion: reduce){
  .cam{transition:none}
}

.ticks line{stroke:var(--ink);stroke-width:.4;opacity:.35}
.ticks text{font-family:'IBM Plex Mono',monospace;font-size:9px;fill:var(--ink);opacity:.55;letter-spacing:.1em}

/* constellation */
.cons{cursor:pointer;outline:none}
.cons:focus-visible{outline:2px solid var(--accent);outline-offset:3px;border-radius:4px}
.cons:focus-visible .hull{stroke:var(--accent);stroke-width:1.4;stroke-dasharray:none;opacity:1}
.cons .hull{fill:rgba(27,74,138,.025);stroke:var(--ink);stroke-width:.6;stroke-dasharray:3 5;opacity:.55;transition:opacity .35s ease, fill .35s ease, stroke-width .35s ease, stroke .25s ease}
.cons:hover .hull,.cons.lit .hull{opacity:1;fill:rgba(27,74,138,.06);stroke-width:.9}
.cons .clabel{font-family:'Cormorant Garamond',serif;font-style:italic;font-size:18px;fill:var(--ink);letter-spacing:.04em;text-anchor:middle;pointer-events:none;transition:opacity .35s ease}
.cons .csub{font-family:'IBM Plex Mono',monospace;font-size:8.5px;fill:var(--ink-soft);letter-spacing:.22em;text-anchor:middle;pointer-events:none;text-transform:uppercase;transition:opacity .35s ease}
/* single-mode pages declare the constellation name in the page header — hide the in-chart label */
.sky-svg.single-mode .cons .clabel,
.sky-svg.single-mode .cons .csub{display:none}
/* single-mode: light the figure label by default since there's only one constellation */
.sky-svg.single-mode .cons .figure-label{opacity:.55}

/* T3(c) — named line clusters (hairline figure labels per constellation) */
.cons .figure-label{font-family:'Cormorant Garamond',serif;font-style:italic;font-size:10px;fill:var(--ink-soft);text-anchor:middle;letter-spacing:.06em;pointer-events:none;opacity:0;transition:opacity .35s ease}
.cons:hover .figure-label,.cons.lit .figure-label{opacity:.55}

/* edges within constellation — faint figure visible at the sky level so the dots
   read as a constellation; pathLength=1 lets us "ink it in" on entry */
.cons .edge{stroke:var(--ink);stroke-width:.6;opacity:.18;stroke-dasharray:1;stroke-dashoffset:0;transition:opacity .35s ease}
.cons .edge.conj{stroke:var(--accent);stroke-dasharray:2 5;stroke-dashoffset:0}
/* once a constellation is picked, draw its figure lines solid like a real chart,
   and fade the boundary hull so the figure (not the box) reads */
.cons.entered .edge{opacity:.55;animation:draw-on .55s ease var(--ed,0s) backwards}
.cons.entered .edge.conj{opacity:.7;animation:none}
.cons.entered .hull{opacity:.16;pointer-events:none}
/* breadcrumb already names the entered constellation — drop the in-chart title so it can't sit on a star label */
.cons.entered .clabel,.cons.entered .csub{opacity:0}
@keyframes draw-on{from{stroke-dashoffset:1}to{stroke-dashoffset:0}}
@media (prefers-reduced-motion: reduce){ .cons.entered .edge{animation:none} }

/* stars */
.star{cursor:pointer;outline:none}
.star .hit{fill:transparent;pointer-events:all}
/* pause twinkle when tab hidden / chart off-screen */
.anim-paused .graticule .bgstar.tw{animation-play-state:paused}
/* sticky "back to the sky" — mobile only, while zoomed into a constellation */
.skyback{display:none;position:fixed;left:50%;bottom:16px;transform:translateX(-50%);z-index:40;background:var(--ink);color:var(--paper);border:0;border-radius:999px;padding:11px 20px;font-family:'IBM Plex Mono',monospace;font-size:11px;letter-spacing:.16em;text-transform:uppercase;cursor:pointer;box-shadow:0 4px 16px rgba(0,0,0,.25)}
@media (max-width:720px){ body.zoomed .skyback{display:block} }
.star:focus-visible .hit{stroke:var(--accent);stroke-width:1.5;fill:rgba(27,74,138,.06)}
.star:focus-visible .dot,.star:focus-visible .ring{filter:drop-shadow(0 0 2px var(--accent))}
.star .dot{fill:var(--ink);transition:r .25s ease, filter .25s ease}
.star .ring{fill:var(--paper);stroke:var(--ink);stroke-width:1.5;transition:r .25s ease}
.star .glabel{font-family:'Cormorant Garamond',serif;font-style:italic;font-weight:700;font-size:11px;fill:var(--ink-faint);pointer-events:none;letter-spacing:.02em;paint-order:stroke;stroke:var(--paper);stroke-width:2.5px;stroke-linejoin:round}
/* names: upright, a touch larger, with a paper halo so they stay legible over the grid */
.star .nlabel{font-family:'Cormorant Garamond',serif;font-style:normal;font-weight:600;font-size:13px;fill:var(--ink);pointer-events:none;paint-order:stroke;stroke:var(--paper);stroke-width:3px;stroke-linejoin:round}
.star.right .glabel,.star.right .nlabel{text-anchor:end}
.star.left .glabel,.star.left .nlabel{text-anchor:start}
/* Star names stay hidden at the sky level (dots + Greek designations only) until a constellation is picked (entered/focused) */
.star .nlabel{opacity:0;transition:opacity .32s ease}
.cons.entered .star .nlabel{opacity:1}
.cons .leader{stroke:var(--ink-faint);stroke-width:.4;opacity:0;transition:opacity .32s ease}
.cons.entered .leader{opacity:.4}
.star.m1 .dot{r:5}
.star.m2 .dot{r:3.8}
.star.m3 .dot{r:2.8}
.star.m4 .dot{r:2}
/* T1 — rim halo on bright stars */
.star.m1 .dot{filter:drop-shadow(0 0 .8px var(--paper)) drop-shadow(0 0 .4px var(--ink))}
.star.m2 .dot{filter:drop-shadow(0 0 .6px var(--paper))}
.star:hover .dot{filter:drop-shadow(0 0 3px var(--accent))}
.star:hover .ring{stroke:var(--accent)}

/* compass minimap (only on home) */
.compass{position:absolute;right:16px;bottom:16px;width:70px;height:70px;background:var(--paper);border:1px solid var(--ink);z-index:3}
@media (max-width:720px){
  .compass{width:50px;height:50px;right:10px;bottom:10px}
  .compass text{font-size:8px}
}
.compass svg{display:block;width:100%;height:100%}
.compass line{stroke:var(--ink);stroke-width:.6}
.compass circle{fill:none;stroke:var(--ink);stroke-width:.6}
.compass .needle{fill:var(--accent)}
.compass text{font-family:'IBM Plex Mono',monospace;font-size:9px;fill:var(--ink);letter-spacing:.1em;text-anchor:middle}

/* breadcrumb (shown when zoomed) */
.breadcrumb{position:absolute;top:14px;left:14px;background:var(--paper);border:1px solid var(--ink);padding:6px 12px;font-family:'IBM Plex Mono',monospace;font-size:10px;letter-spacing:.18em;text-transform:uppercase;z-index:5;display:flex;align-items:center;gap:8px}
.breadcrumb .step{color:var(--ink);font-family:'Cormorant Garamond',serif;font-style:italic;font-size:13px;letter-spacing:.02em;text-transform:none}
.breadcrumb button.zoom-out{background:none;border:0;font-family:'IBM Plex Mono',monospace;font-size:9px;letter-spacing:.18em;text-transform:uppercase;cursor:pointer;color:var(--accent);padding:8px 10px;margin:-6px -4px;text-decoration:underline;min-height:24px}
.breadcrumb a.plate-link{color:var(--accent);text-decoration:underline;font-family:'Cormorant Garamond',serif;font-style:italic;font-size:13px;letter-spacing:.02em;text-transform:none}

/* longform sections below the chart on section pages */
.scroll{max-width:1180px;margin:0 auto;background:var(--paper);border:1.5px solid var(--ink);border-top:0;padding:42px 56px 56px;position:relative;z-index:4;box-shadow:0 1px 0 var(--ink),0 2px 0 var(--ink)}
.scroll h2{font-family:'Cormorant Garamond',serif;font-style:italic;font-size:30px;font-weight:500;margin-bottom:6px}
.scroll .h-sub{font-family:'IBM Plex Mono',monospace;font-size:10px;letter-spacing:.22em;text-transform:uppercase;color:var(--ink-faint);margin-bottom:24px;display:block}
.scroll h3{font-family:'Cormorant Garamond',serif;font-style:italic;font-size:20px;font-weight:500;margin:24px 0 6px}
.scroll p{font-size:15px;line-height:1.65;margin-bottom:14px;max-width:780px}
.scroll .lede{font-style:italic;font-size:17px;max-width:780px;margin-bottom:24px}
.scroll .rule{border:0;border-top:1px solid var(--ink);margin:32px 0 24px;opacity:.4}
.scroll a{color:var(--accent);text-decoration:underline;text-decoration-thickness:1px;text-underline-offset:3px}
@media (max-width:720px){
  .scroll{padding:28px 22px 36px}
  .scroll h2{font-size:24px}
}

/* career project list */
.entries{list-style:none;display:grid;grid-template-columns:repeat(auto-fit,minmax(320px,1fr));gap:20px;margin:18px 0 24px}
.entries li{border:1px solid var(--ink);border-style:none none none solid;border-left-width:2px;padding:8px 0 8px 16px}
.entries h3{font-size:17px;margin:0 0 6px}
.entries p{font-size:14px;line-height:1.55;margin:0;color:var(--ink-soft)}

/* pricing plans */
.plans{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:18px;margin:8px 0 28px}
.plan{border:1px solid var(--ink);padding:22px;background:var(--paper);position:relative;display:flex;flex-direction:column}
.plan.highlight{border-width:2px;background:rgba(27,74,138,.04)}
.plan .badge{position:absolute;top:-10px;left:18px;background:var(--paper);padding:0 8px;font-family:'IBM Plex Mono',monospace;font-size:9px;letter-spacing:.22em;text-transform:uppercase;color:var(--accent)}
.plan .tier{font-family:'Cormorant Garamond',serif;font-style:italic;font-size:20px;font-weight:500;margin-bottom:4px}
.plan .price{font-family:'Cormorant Garamond',serif;font-size:32px;font-weight:700;line-height:1}
.plan .price .unit{font-size:14px;font-weight:400;font-style:italic;color:var(--ink-soft)}
.plan .setup{font-family:'IBM Plex Mono',monospace;font-size:9px;letter-spacing:.18em;text-transform:uppercase;color:var(--ink-faint);margin:6px 0 12px}
.plan p{font-size:14px;line-height:1.55;margin-bottom:14px;color:var(--ink-soft);flex:0 0 auto}
.plan ul{list-style:none;padding:0;margin:0 0 16px;font-size:13.5px;line-height:1.7;flex:1 1 auto}
.plan li::before{content:'· ';color:var(--accent);font-weight:700}
.plan .cta{display:inline-block;border:1px solid var(--ink);padding:10px 16px;text-decoration:none;text-align:center;font-family:'IBM Plex Mono',monospace;font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--ink);background:var(--paper);transition:background .15s, color .15s;margin-top:auto}
.plan .cta:hover{background:var(--ink);color:var(--paper)}
.plan.highlight .cta{background:var(--accent);color:var(--paper);border-color:var(--accent)}
.plan.highlight .cta:hover{background:var(--ink);border-color:var(--ink)}

/* opinions plate */
.opinions{counter-reset:op}
.opinions article{padding:22px 0;border-bottom:1px solid rgba(10,10,10,.2)}
.opinions article:last-child{border-bottom:0}
.opinions .num{font-family:'Cormorant Garamond',serif;font-style:italic;font-size:18px;color:var(--accent);margin-bottom:6px;letter-spacing:.06em}
.opinions h3{margin:0 0 6px}

/* records (Discus Anni) */
.records{list-style:none;padding:0;display:grid;grid-template-columns:1fr 1fr;gap:0;border-top:1px solid var(--ink)}
.records li{display:grid;grid-template-columns:32px 1fr auto;align-items:baseline;padding:10px 14px;border-bottom:1px dashed rgba(10,10,10,.25);font-size:15px;line-height:1.4;gap:10px}
.records li:nth-child(2n){border-right:1px solid rgba(10,10,10,.15)}
.records .n{font-family:'IBM Plex Mono',monospace;font-size:11px;color:var(--ink-soft);letter-spacing:.12em}
.records .title{font-style:italic}
.records .greek{font-family:'Cormorant Garamond',serif;font-style:italic;color:var(--ink-soft);font-size:13px}
@media (max-width:720px){
  .records{grid-template-columns:1fr}
}

/* contact form */
.form{max-width:600px;margin:0;display:grid;gap:14px}
.form label{font-family:'IBM Plex Mono',monospace;font-size:10px;letter-spacing:.18em;text-transform:uppercase;color:var(--ink-soft);display:block;margin-bottom:4px}
.form input,.form textarea{width:100%;background:var(--paper);border:1px solid var(--ink);padding:10px 12px;font-family:'Cormorant Garamond',serif;font-size:15px;color:var(--ink);font-style:italic}
.form input:focus,.form textarea:focus{outline:1px solid var(--accent);outline-offset:1px}
.form textarea{min-height:140px;resize:vertical}
.form button{justify-self:start;background:var(--ink);color:var(--paper);border:0;padding:12px 22px;font-family:'IBM Plex Mono',monospace;font-size:11px;letter-spacing:.22em;text-transform:uppercase;cursor:pointer}
.form button:hover{background:var(--accent)}
.form .status{font-family:'IBM Plex Mono',monospace;font-size:10px;letter-spacing:.18em;text-transform:uppercase;color:var(--accent);margin-top:6px;min-height:14px}

/* card (star detail modal) */
.card-overlay{position:fixed;inset:0;background:rgba(10,10,10,.58);z-index:50;display:none;align-items:center;justify-content:center;padding:24px}
.card-overlay.open{display:flex;animation:overlayIn .25s ease both}
.card{background:var(--paper);border:1.5px solid var(--ink);max-width:540px;width:100%;max-height:82vh;overflow-y:auto;padding:34px 36px;position:relative;box-shadow:0 1px 0 var(--ink),0 2px 0 var(--ink),0 18px 50px rgba(0,0,0,.32);animation:cardIn .32s cubic-bezier(.2,.9,.3,1) both}
@keyframes overlayIn{from{opacity:0}to{opacity:1}}
@keyframes cardIn{from{opacity:0;transform:translateY(14px) scale(.985)}to{opacity:1;transform:none}}
@media (max-width:720px){
  .card-overlay{align-items:flex-end;padding:0}
  .card{max-width:none;max-height:88vh;border-width:2px 0 0;padding:26px 22px 32px;box-shadow:0 -10px 40px rgba(0,0,0,.3);animation:sheetIn .34s cubic-bezier(.2,.9,.3,1) both}
}
@keyframes sheetIn{from{transform:translateY(100%)}to{transform:none}}
.card .close{position:absolute;top:8px;right:8px;background:none;border:0;font-family:'IBM Plex Mono',monospace;font-size:11px;letter-spacing:.18em;color:var(--ink-soft);cursor:pointer;padding:10px 12px;min-width:44px;min-height:44px}
.card .close:hover{color:var(--accent)}
.card .greek{font-family:'Cormorant Garamond',serif;font-style:italic;font-size:32px;color:var(--accent);float:left;margin:-2px 14px 0 0;line-height:1}
.card h2{font-family:'Cormorant Garamond',serif;font-style:italic;font-weight:500;font-size:26px;margin-bottom:2px}
.card .sub{font-family:'IBM Plex Mono',monospace;font-size:10px;letter-spacing:.18em;text-transform:uppercase;color:var(--ink-soft);margin-bottom:14px}
.card p{font-size:15px;line-height:1.6;margin-bottom:14px}
.card .hi{list-style:none;margin:0 0 14px;padding:0}
.card .hi li{position:relative;font-size:13.5px;line-height:1.5;color:var(--ink-soft);padding:0 0 8px 16px}
.card .hi li::before{content:'·';position:absolute;left:2px;top:-1px;color:var(--accent);font-weight:700}
.card .shot{display:block;width:100%;height:auto;border:1px solid var(--ink);margin:0 0 16px;background:var(--paper)}
.card .hi li strong{color:var(--ink);font-weight:600}
.card .stack{font-family:'IBM Plex Mono',monospace;font-size:10.5px;line-height:1.55;letter-spacing:.03em;color:var(--ink-soft);margin:0 0 14px}
.card .links{display:flex;gap:14px;margin-top:16px;font-family:'IBM Plex Mono',monospace;font-size:11px;letter-spacing:.18em;text-transform:uppercase}
.card .links a{color:var(--accent);text-decoration:underline}
.card .kind{font-family:'IBM Plex Mono',monospace;font-size:9px;letter-spacing:.22em;text-transform:uppercase;color:var(--ink-faint);margin-top:14px;padding-top:14px;border-top:1px solid rgba(10,10,10,.2)}

/* text-plate (opinions/records/contact — no sky chart, just engraved text) */
.text-plate{padding-bottom:42px}
.text-plate .articles,
.text-plate .records-grid,
.text-plate .form-wrap{padding:30px 56px 0;position:relative;z-index:4}
.text-plate .lede{font-style:italic;font-size:17px;max-width:780px;margin-bottom:24px;line-height:1.6}
.text-plate .lede a{color:var(--accent);text-decoration:underline;text-decoration-thickness:1px;text-underline-offset:3px}
.text-plate .returnto{padding:18px 56px 0;font-family:'IBM Plex Mono',monospace;font-size:11px;letter-spacing:.18em;text-transform:uppercase;position:relative;z-index:4}
.text-plate .returnto a{color:var(--accent);text-decoration:underline}
@media (max-width:720px){
  .text-plate .articles,
  .text-plate .records-grid,
  .text-plate .form-wrap{padding:24px 22px 0}
  .text-plate .returnto{padding:14px 22px 0}
}

/* project detail plate (aperture-depth write-ups) */
.proj{max-width:760px;padding:30px 56px 48px;position:relative;z-index:4}
.proj .meta{font-family:'IBM Plex Mono',monospace;font-size:10.5px;letter-spacing:.2em;text-transform:uppercase;color:var(--ink-faint);margin-bottom:10px}
.proj h1{font-family:'Cormorant Garamond',serif;font-weight:500;font-style:italic;font-size:40px;line-height:1.05;margin-bottom:8px}
.proj .tagline{font-size:18px;font-style:italic;color:var(--ink-soft);line-height:1.5;margin-bottom:26px;max-width:640px}
.proj figure.media{margin:0 0 28px;border:1.5px solid var(--ink);background:var(--paper);box-shadow:0 1px 0 var(--ink),0 2px 0 var(--ink)}
.proj figure.media img,.proj figure.media video{display:block;width:100%;height:auto;background:var(--paper)}
.proj figure.media figcaption{font-family:'IBM Plex Mono',monospace;font-size:10px;letter-spacing:.14em;text-transform:uppercase;color:var(--ink-faint);padding:8px 12px;border-top:1px solid rgba(10,10,10,.2)}
.proj h2{font-family:'IBM Plex Mono',monospace;font-size:12px;letter-spacing:.22em;text-transform:uppercase;color:var(--ink-soft);margin:32px 0 12px;border-bottom:1px solid rgba(10,10,10,.2);padding-bottom:6px}
.proj p{font-size:15.5px;line-height:1.68;color:var(--ink-soft);max-width:660px;margin-bottom:14px}
.proj ul{list-style:none;margin:0 0 16px;padding:0;max-width:660px}
.proj ul li{position:relative;font-size:15px;line-height:1.6;color:var(--ink-soft);padding:0 0 10px 18px}
.proj ul li::before{content:'·';position:absolute;left:2px;top:-1px;color:var(--accent);font-weight:700}
.proj ul li strong{color:var(--ink);font-weight:600}
.proj .stack{font-family:'IBM Plex Mono',monospace;font-size:11.5px;line-height:1.6;letter-spacing:.03em;color:var(--ink-soft);max-width:660px}
.proj .cta{display:flex;gap:18px;flex-wrap:wrap;margin-top:28px;font-family:'IBM Plex Mono',monospace;font-size:12px;letter-spacing:.18em;text-transform:uppercase}
.proj .cta a{color:var(--accent);text-decoration:underline;text-underline-offset:3px}
@media (max-width:720px){
  .proj{padding:24px 22px 40px}
  .proj h1{font-size:32px}
  .proj .tagline{font-size:16px}
}

/* opinions plate — engraved articles */
.articles{display:block}
.articles .op{padding:24px 0;border-bottom:1px solid rgba(10,10,10,.2);max-width:820px}
.articles .op:last-child{border-bottom:0}
.articles .op .num{font-family:'Cormorant Garamond',serif;font-style:italic;font-size:20px;color:var(--accent);margin-bottom:6px;letter-spacing:.06em;font-weight:700}
.articles .op h2{font-family:'Cormorant Garamond',serif;font-weight:500;font-style:italic;font-size:24px;line-height:1.2;margin-bottom:10px}
.articles .op p{font-size:15.5px;line-height:1.65;color:var(--ink-soft);max-width:760px}
@media (max-width:720px){
  .articles .op h2{font-size:20px}
}

/* records-grid (Discus Anni) — engraved record cards */
.records-grid{display:grid;grid-template-columns:1fr 1fr;gap:0;border-top:1px solid var(--ink);border-left:1px solid rgba(10,10,10,.15)}
.records-grid .rec{padding:18px 22px;border-bottom:1px dashed rgba(10,10,10,.25);border-right:1px solid rgba(10,10,10,.15);position:relative;display:grid;grid-template-columns:38px 1fr;column-gap:14px;row-gap:6px;align-items:start}
.records-grid .rec-num{font-family:'Cormorant Garamond',serif;font-style:italic;font-size:24px;color:var(--accent);line-height:1;padding-top:2px;grid-column:1;grid-row:1 / span 2}
.records-grid .rec h3{font-family:'Cormorant Garamond',serif;font-weight:500;font-size:17px;line-height:1.25;grid-column:2;grid-row:1}
.records-grid .rec h3 i{font-style:italic;color:var(--ink)}
.records-grid .rec p{font-size:14px;line-height:1.55;color:var(--ink-soft);margin:0;grid-column:2;grid-row:2}
@media (max-width:720px){
  .records-grid{grid-template-columns:1fr}
}

/* contact form (ink-form) */
.ink-form{max-width:580px;display:grid;gap:16px;margin-top:8px}
.ink-form .field{display:block}
.ink-form label{font-family:'IBM Plex Mono',monospace;font-size:10px;letter-spacing:.18em;text-transform:uppercase;color:var(--ink-soft);display:block;margin-bottom:6px}
.ink-form input,.ink-form textarea{width:100%;background:var(--paper);border:1px solid var(--ink);padding:10px 12px;font-family:'Cormorant Garamond',serif;font-size:16px;color:var(--ink);font-style:italic}
.ink-form input:focus,.ink-form textarea:focus{outline:1px solid var(--accent);outline-offset:1px}
.ink-form textarea{min-height:160px;resize:vertical;line-height:1.5}
.ink-form .honeypot{position:absolute;left:-9999px;top:auto;width:1px;height:1px;overflow:hidden}
.ink-form .cta{justify-self:start;background:var(--ink);color:var(--paper);border:1px solid var(--ink);padding:12px 22px;font-family:'IBM Plex Mono',monospace;font-size:11px;letter-spacing:.22em;text-transform:uppercase;cursor:pointer;text-decoration:none;display:inline-block}
.ink-form .cta:hover{background:var(--accent);border-color:var(--accent)}
.ink-form .cta:disabled{opacity:.6;cursor:not-allowed}
.ink-form .status{font-family:'IBM Plex Mono',monospace;font-size:10.5px;letter-spacing:.16em;text-transform:uppercase;margin-top:4px;display:none}
.ink-form .status[data-kind="info"]{color:var(--ink-soft);display:block}
.ink-form .status[data-kind="success"]{color:var(--accent);display:block}
.ink-form .status[data-kind="error"]{color:#a02020;display:block}

/* colophon */
.colophon{max-width:1180px;margin:24px auto 0;font-family:'IBM Plex Mono',monospace;font-size:10px;letter-spacing:.18em;text-transform:uppercase;color:var(--ink-soft);text-align:center;line-height:1.8;padding:0 22px}
.colophon a{color:var(--accent);text-decoration:underline}
.colophon .orn{display:block;font-size:14px;letter-spacing:.6em;color:var(--ink);margin-bottom:6px;font-family:serif}

/* ====================================================================
   Mobile overrides — strip ornamentation that doesn't fit < 720px.
   The Greek-key meander, SVG corner fleurons, paper-noise filter, and
   the in-chart grid+star background all eat horizontal room and add
   visual weight that overwhelms a 375px screen. Mobile reads as a
   clean editorial broadside instead — closer to the site-map.html
   reference that locked the aesthetic.
   ==================================================================== */
@media (max-width:720px){
  body{padding:18px 14px 40px;background-size:380px 380px,460px 460px,320px 320px,420px 420px,340px 340px}

  /* outer plate — drop the meander strips + fleurons + paper noise */
  .meander-frame{display:none}
  .corner{display:none}
  .chart::before{display:none}
  .chart{box-shadow:0 1px 0 var(--ink),0 6px 18px rgba(0,0,0,.1)}

  /* simple right-angle bracket corners instead of fleurons, like the reference */
  .chart{position:relative}
  .chart::after{content:'';position:absolute;top:10px;left:10px;width:14px;height:14px;border-top:1.2px solid var(--ink);border-left:1.2px solid var(--ink);pointer-events:none;z-index:5}
  .chart > .header::before,.chart > .header::after{content:'';position:absolute;width:14px;height:14px;pointer-events:none}
  .chart > .header::before{top:-4px;right:10px;border-top:1.2px solid var(--ink);border-right:1.2px solid var(--ink)}
  .chart > .header{position:relative}

  /* compact header */
  .header{padding:18px 18px 12px;gap:6px;border-bottom:1.2px solid var(--ink)}
  .header .l,.header .r{font-size:9.5px;letter-spacing:.16em;line-height:1.6}
  .header .l b,.header .r b{font-size:12px;letter-spacing:.06em}
  .header .c h1{font-size:32px}
  .header .c .orn{font-size:14px;margin-bottom:4px}
  .header .c .sub{font-size:9.5px;letter-spacing:.24em;margin-top:6px}

  /* preface — let drop-cap and prose breathe, single column already set above */
  .preface{padding:14px 18px 14px;font-size:13.5px;line-height:1.55;gap:14px}
  .preface .legend{font-size:9px;line-height:1.85;padding-top:10px}

  /* sky-wrap — single thin border, no nested decoration */
  .sky-wrap{margin:0 18px 16px;border-width:1px}
  .sky-wrap::before,.sky-wrap::after{display:none}

  /* nav — brand on its own line, menu thin row below, editorial style */
  .nav{flex-direction:column;align-items:flex-start;gap:8px;margin-bottom:14px;padding:0 4px}
  .nav .brand{font-size:16px}
  .nav ul{flex-wrap:nowrap;gap:14px;font-size:9px;letter-spacing:.14em;justify-content:flex-start;width:100%;overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none}
  .nav ul::-webkit-scrollbar{display:none}
  .nav a{white-space:nowrap}

  /* longform sections — tighter padding */
  .scroll{padding:24px 18px 32px;border-width:1.2px;box-shadow:0 1px 0 var(--ink),0 6px 18px rgba(0,0,0,.1)}
  .scroll::before{display:none}

  /* text-plate body padding to match */
  .text-plate .articles,
  .text-plate .records-grid,
  .text-plate .form-wrap{padding:20px 18px 0}
  .text-plate .returnto{padding:14px 18px 0}

  /* colophon tighter */
  .colophon{padding:0 10px;font-size:9px;letter-spacing:.14em}

  /* chart is the hero on mobile: compact title → the sky → intro/legend below.
     Scoped away from .text-plate (contact/records/writing) which have no chart. */
  main.chart:not(.text-plate){display:flex;flex-direction:column}
  main.chart:not(.text-plate) > .header{order:0}
  main.chart:not(.text-plate) > #sky-wrap{order:1}
  main.chart:not(.text-plate) > .preface{order:2}
  main.chart:not(.text-plate) > .sr-only,main.chart:not(.text-plate) > noscript{order:3}
  .header{border-bottom:0}
  #sky-wrap{margin:12px 14px 16px !important;aspect-ratio:auto !important}
  .preface{border-bottom:0;border-top:1px solid var(--ink)}
  .preface .legend{border-left:0;padding-left:0;padding-top:10px}
  /* perf: don't run 150 infinite twinkles or the displacement filter on phones */
  .graticule .bgstar{animation:none}
  .cons .edge,.cons .hull{filter:none}
}
