/*! crochet gallery v2.0 — minified · reset · tokens · ticker · nav · hero · cats · collage · band · diary · about · club · post · comments · footer */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}html{-webkit-text-size-adjust:100%;text-size-adjust:100%;scroll-behavior:smooth}
:root{--cream:#fff3e9;--cream-deep:#fce5d3;--rose:#ffd7e1;--rose-mid:#f6a4bd;--rose-hot:#e63b67;--cherry:#c8254d;--berry:#7b1b3e;--plum:#9b5d8a;--butter:#f7d04e;--ink:#2a0e1a;--shadow:0 18px 36px -22px #2a0e1a66;--ring:0 0 0 1.5px var(--ink);--gingham-a:#ffd0dd;--gingham-b:#df5078;--scallop:30px}
body{min-height:100vh;font-family:'Fraunces','Fraunces-fb',ui-serif,Georgia,serif;font-optical-sizing:auto;font-variation-settings:"opsz" 14,"SOFT" 50;font-weight:400;color:var(--ink);background:var(--cream);overflow-x:hidden;line-height:1.5;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}
img,svg,video,canvas{display:block;max-width:100%}button,input,textarea{font:inherit;color:inherit;border:0;background:none}button{cursor:pointer}a{color:inherit;text-decoration:none}ol,ul{list-style:none}em{font-style:italic}b,strong{font-weight:600}
/* self-hosted variable Fraunces + DM Mono (latin + latin-ext subsets) */
@font-face{font-family:'Fraunces';font-style:normal;font-weight:100 900;font-display:swap;src:url(/assets/fonts/fraunces-normal.woff2) format('woff2');unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}
@font-face{font-family:'Fraunces';font-style:italic;font-weight:100 900;font-display:swap;src:url(/assets/fonts/fraunces-italic.woff2) format('woff2');unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}
@font-face{font-family:'Fraunces';font-style:normal;font-weight:100 900;font-display:swap;src:url(/assets/fonts/fraunces-normal-ext.woff2) format('woff2');unicode-range:U+0100-02BA,U+02BD-02C5,U+02C7-02CC,U+02CE-02D7,U+02DD-02FF,U+0304,U+0308,U+0329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}
@font-face{font-family:'Fraunces';font-style:italic;font-weight:100 900;font-display:swap;src:url(/assets/fonts/fraunces-italic-ext.woff2) format('woff2');unicode-range:U+0100-02BA,U+02BD-02C5,U+02C7-02CC,U+02CE-02D7,U+02DD-02FF,U+0304,U+0308,U+0329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}
@font-face{font-family:'DM Mono';font-style:normal;font-weight:400;font-display:swap;src:url(/assets/fonts/dm-mono-400.woff2) format('woff2');unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}
@font-face{font-family:'DM Mono';font-style:normal;font-weight:500;font-display:swap;src:url(/assets/fonts/dm-mono-500.woff2) format('woff2');unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}
@font-face{font-family:'DM Mono';font-style:normal;font-weight:400;font-display:swap;src:url(/assets/fonts/dm-mono-400-ext.woff2) format('woff2');unicode-range:U+0100-02BA,U+02BD-02C5,U+02C7-02CC,U+02CE-02D7,U+02DD-02FF,U+0304,U+0308,U+0329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}
@font-face{font-family:'DM Mono';font-style:normal;font-weight:500;font-display:swap;src:url(/assets/fonts/dm-mono-500-ext.woff2) format('woff2');unicode-range:U+0100-02BA,U+02BD-02C5,U+02C7-02CC,U+02CE-02D7,U+02DD-02FF,U+0304,U+0308,U+0329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}
/* metric-override fallbacks to prevent CLS during swap */
@font-face{font-family:'Fraunces-fb';src:local('Georgia'),local('Times New Roman');size-adjust:104%;ascent-override:92%;descent-override:24%;line-gap-override:0%}
@font-face{font-family:'DM-Mono-fb';src:local('Menlo'),local('Consolas'),local('Courier New');size-adjust:106%;ascent-override:88%;descent-override:22%}
.vh{position:absolute!important;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0 0 0 0);white-space:nowrap;border:0}
.dot{color:var(--rose-hot);padding:0 .35em}
/* ===== TICKER ===== */
.tk{height:34px;background:var(--ink);color:var(--cream);overflow:hidden;position:sticky;top:0;z-index:50}
.tk__t{display:flex;gap:36px;align-items:center;height:100%;white-space:nowrap;font:500 11px/1 'DM Mono','DM-Mono-fb',monospace;letter-spacing:.22em;text-transform:lowercase;animation:tk 38s linear infinite;width:max-content;padding-left:36px}
.tk__i{opacity:.92}
.tk__d{color:var(--rose-mid);font-size:13px}
@keyframes tk{to{transform:translateX(-50%)}}
/* ===== NAV ===== */
.nv{position:relative;display:grid;grid-template-columns:1fr auto 1fr;align-items:center;gap:18px;padding:24px clamp(20px,4vw,52px) 38px;background:var(--cream);z-index:40}
.nv__l,.nv__r{display:flex;align-items:center;gap:24px}
.nv__r{justify-content:flex-end}
.nv__lnk{font:500 11px/1 'DM Mono','DM-Mono-fb',monospace;letter-spacing:.24em;text-transform:lowercase;color:var(--ink);position:relative;padding:6px 0}
.nv__lnk::after{content:"";position:absolute;left:0;right:0;bottom:-4px;height:2px;background:var(--rose-hot);transform:scaleX(0);transform-origin:left;transition:transform .35s cubic-bezier(.6,0,.2,1)}
.nv__lnk:hover::after{transform:scaleX(1)}
.nv__b{display:inline-block;line-height:1}
.nv__mk{font:italic 600 30px/1 'Fraunces','Fraunces-fb',serif;font-variation-settings:"opsz" 144;color:var(--cherry);letter-spacing:-.02em}
.nv__sr{width:34px;height:34px;display:grid;place-items:center;border-radius:50%;color:var(--ink);transition:background .25s}
.nv__sr:hover{background:#0000000d}
/* scalloped underside of nav strip into gingham */
.nv__scallop{position:absolute;left:0;right:0;bottom:0;height:var(--scallop);background:var(--cream);-webkit-mask:radial-gradient(circle var(--scallop) at calc(var(--scallop)*0.5) 0, #0000 99%, #000 101%) calc(var(--scallop)*-.5) 0/var(--scallop) var(--scallop) repeat-x;mask:radial-gradient(circle var(--scallop) at calc(var(--scallop)*0.5) 0, #0000 99%, #000 101%) calc(var(--scallop)*-.5) 0/var(--scallop) var(--scallop) repeat-x;pointer-events:none}
/* ===== HERO ===== */
.hr{position:relative;padding:0 clamp(14px,3vw,40px) 64px;min-height:660px;display:grid;place-items:center;isolation:isolate}
.hr__bg{position:absolute;inset:0;z-index:-1;background:
  conic-gradient(var(--gingham-b) 25%, var(--gingham-a) 0 50%, var(--gingham-b) 0 75%, var(--gingham-a) 0) 0 0/44px 44px;
  background-blend-mode:multiply;
  background-color:var(--gingham-a)}
.hr__bg::before{content:"";position:absolute;inset:0;background:
  conic-gradient(var(--gingham-b) 25%, var(--gingham-a) 0 50%, var(--gingham-b) 0 75%, var(--gingham-a) 0) 22px 22px/44px 44px;
  mix-blend-mode:multiply;opacity:.45}
.hr__card{background:var(--cream);max-width:820px;width:100%;padding:clamp(32px,3.6vw,56px) clamp(24px,4vw,72px);position:relative;border-radius:22px;text-align:center;display:flex;flex-direction:column;align-items:center;gap:16px;box-shadow:var(--shadow);border:2px solid var(--ink);margin:56px 0 64px}
.hr__card::before{content:"";position:absolute;left:0;right:0;top:0;height:34px;background:var(--rose-mid);-webkit-mask:radial-gradient(circle 16px at 16px 34px,#0000 16px,#000 17px) 0 0/32px 34px repeat-x;mask:radial-gradient(circle 16px at 16px 34px,#0000 16px,#000 17px) 0 0/32px 34px repeat-x;border-radius:20px 20px 0 0;pointer-events:none;z-index:1}
.hr__card::after{content:"";position:absolute;inset:0;border:2px solid var(--ink);border-radius:22px;pointer-events:none}
.hr__card>*{position:relative;z-index:2}
.hr__card{border:0;padding-top:clamp(46px,5vw,72px)}
.hr__eyebrow{font:500 11px/1 'DM Mono','DM-Mono-fb',monospace;letter-spacing:.32em;text-transform:lowercase;color:var(--cherry);padding:8px 14px;border:1.5px solid var(--cherry);border-radius:999px;background:#fff}
.hr__title{font:600 clamp(48px,6.8vw,88px)/.98 'Fraunces','Fraunces-fb',serif;font-variation-settings:"opsz" 144;color:var(--berry);letter-spacing:-.022em;max-width:680px}
.hr__title em{color:var(--rose-hot);font-style:italic}
.hr__title em{color:var(--rose-hot)}
.hr__dek{font-size:17px;line-height:1.55;color:#2a0e1ac0;max-width:560px;font-family:'Fraunces','Fraunces-fb',serif;font-variation-settings:"opsz" 14}
.hr__cta{display:flex;gap:12px;flex-wrap:wrap;justify-content:center;margin-top:6px}
.hr__meta{display:flex;align-items:center;gap:4px;flex-wrap:wrap;justify-content:center;padding-top:14px;border-top:1px dashed #2a0e1a30;font:500 11px/1 'DM Mono','DM-Mono-fb',monospace;letter-spacing:.18em;text-transform:lowercase;color:#2a0e1aa8;margin-top:6px;align-self:stretch;min-width:0}
.hr__meta b{font-weight:600;color:var(--cherry);font-variant-numeric:tabular-nums}
/* buttons */
.bt{display:inline-flex;align-items:center;gap:8px;padding:14px 22px;border-radius:999px;font:500 12px/1 'DM Mono','DM-Mono-fb',monospace;letter-spacing:.22em;text-transform:lowercase;border:1.5px solid var(--ink);transition:transform .3s cubic-bezier(.5,.1,.2,1),background .3s,color .3s,box-shadow .3s;will-change:transform}
.bt i{font-style:normal;display:inline-block;transition:transform .3s}
.bt:hover i{transform:translateX(4px)}
.bt--solid{background:var(--rose-hot);color:var(--cream);box-shadow:0 6px 0 -1px var(--berry)}
.bt--solid:hover{transform:translateY(-2px);box-shadow:0 8px 0 -1px var(--berry)}
.bt--ghost{background:transparent;color:var(--ink)}
.bt--ghost:hover{background:var(--ink);color:var(--cream)}
.bt--cream{background:var(--cream);color:var(--ink);box-shadow:0 6px 0 -1px var(--berry)}
.bt--cream:hover{background:var(--butter);transform:translateY(-2px)}
.bt--pill{background:var(--rose-hot);color:var(--cream);box-shadow:0 5px 0 -1px var(--berry);padding:12px 22px;border-radius:8px;margin-top:6px}
.bt--pill:hover{transform:translateY(-2px);box-shadow:0 7px 0 -1px var(--berry)}
/* stickers floating around hero card */
.st{position:absolute;top:var(--t);left:var(--l);transform:rotate(var(--ang)) scale(var(--sc,1)) translateZ(0);z-index:5;white-space:nowrap;pointer-events:none;animation:wobble 6s ease-in-out infinite;animation-delay:calc((var(--l, 0) + var(--t, 0)) * .03s);transform-origin:center}
@keyframes wobble{0%,100%{transform:rotate(var(--ang)) scale(var(--sc,1)) translateY(0)}50%{transform:rotate(calc(var(--ang) + 1.6deg)) scale(var(--sc,1)) translateY(-4px)}}
.st--pill,.st--oval{font:600 10px/1 'DM Mono','DM-Mono-fb',monospace;letter-spacing:.22em;text-transform:lowercase;padding:10px 14px;background:var(--acc);color:var(--cream);border:1.5px solid var(--ink);box-shadow:0 4px 0 -1px var(--ink)}
.st--oval{color:var(--ink)}
.st--pill{border-radius:999px}
.st--oval{border-radius:50%/60%;padding:14px 20px}
.st--ill{filter:drop-shadow(0 8px 14px #2a0e1a40);color:var(--acc)}
.st__svg{width:84px;height:84px;display:block}
/* ===== SECTION HEADS ===== */
.sx__h{max-width:880px;margin:0 auto 48px;display:flex;flex-direction:column;align-items:center;gap:14px;text-align:center}
.kk{font:500 11px/1 'DM Mono','DM-Mono-fb',monospace;letter-spacing:.32em;text-transform:lowercase;color:var(--berry);padding:6px 12px;background:var(--rose);border-radius:999px;border:1px solid var(--ink)}
.kk--c{display:inline-block;margin:0 auto}
.kk--inv{background:#ffffff14;color:#fff;border-color:#ffffffaa}
.sx__t{font:600 clamp(40px,5.6vw,82px)/.98 'Fraunces','Fraunces-fb',serif;font-variation-settings:"opsz" 144;color:var(--berry);letter-spacing:-.018em}
.sx__t em{color:var(--rose-hot);font-style:italic}
.sx__l{font-size:16px;line-height:1.6;color:#2a0e1ab0;max-width:540px}
/* ===== CATEGORIES ===== */
.cats{padding:64px clamp(20px,4vw,52px)}
.cats__l{display:grid;grid-template-columns:repeat(5,1fr);gap:18px;max-width:1100px;margin:0 auto}
.ch{display:flex;flex-direction:column;align-items:center;gap:12px;padding:28px 18px 22px;background:var(--cream);border:1.5px solid var(--ink);border-radius:22px;box-shadow:0 6px 0 -1px var(--ink);transition:transform .35s cubic-bezier(.2,.7,.2,1),background .3s,color .3s;transform:rotate(var(--tilt,0deg))}
.cats__l li:nth-child(1) .ch{--tilt:-2deg}
.cats__l li:nth-child(2) .ch{--tilt:1.5deg}
.cats__l li:nth-child(3) .ch{--tilt:-1deg}
.cats__l li:nth-child(4) .ch{--tilt:2deg}
.cats__l li:nth-child(5) .ch{--tilt:-1.5deg}
.ch:hover{background:var(--acc);color:var(--cream);transform:rotate(var(--tilt,0deg)) translateY(-6px) scale(1.02)}
.ch__g{width:54px;height:54px;display:grid;place-items:center;border-radius:50%;background:var(--acc);color:var(--cream);font-size:26px;border:1.5px solid var(--ink);transition:background .3s,color .3s}
.ch:hover .ch__g{background:var(--cream);color:var(--acc)}
.ch__n{font:500 12px/1 'DM Mono','DM-Mono-fb',monospace;letter-spacing:.22em;text-transform:lowercase}
/* ===== FEATURE STRIP (3-up trust block, Nectar-style) ===== */
.fs{padding:88px clamp(20px,4vw,52px) 72px;background:var(--cream)}
.fs__l{display:grid;grid-template-columns:repeat(3,1fr);gap:60px clamp(28px,5vw,72px);max-width:1080px;margin:0 auto}
.fs__i{display:flex;flex-direction:column;align-items:center;text-align:center;gap:18px;color:var(--ink);position:relative}
.fs__i::before{content:"";position:absolute;left:-30px;right:-30px;top:0;bottom:0;border-right:1px dashed #2a0e1a26;pointer-events:none}
.fs__i:last-child::before{display:none}
.fs__ic{width:88px;height:88px;display:grid;place-items:center;color:var(--acc);position:relative;animation:wobble 7s ease-in-out infinite;transform-origin:center;--ang:0deg;--sc:1}
.fs__svg{width:88px;height:88px}
.fs__t{font:600 24px/1.18 'Fraunces','Fraunces-fb',serif;font-variation-settings:"opsz" 144;color:var(--berry);letter-spacing:-.012em;max-width:240px;font-style:italic}
.fs__b{font-size:14.5px;line-height:1.55;color:#2a0e1ab0;max-width:280px}

/* ===== FEATURED COLLAGE ===== */
.ft2{padding:72px clamp(20px,4vw,52px) 80px;background:var(--rose);position:relative;border-block:2px solid var(--ink);text-align:center;overflow:hidden}
.ft2::before{content:"";position:absolute;inset:0;background-image:linear-gradient(#fff5 1px,transparent 1px),linear-gradient(90deg,#fff5 1px,transparent 1px);background-size:24px 24px;opacity:.4;pointer-events:none}
.ft2 .kk--c{background:var(--cream);margin:0 auto 14px;display:inline-block;position:relative;z-index:2}
.ft2__t{font:600 clamp(30px,4vw,56px)/1.04 'Fraunces','Fraunces-fb',serif;font-variation-settings:"opsz" 144;color:var(--berry);text-align:center;margin:0 auto 22px;letter-spacing:-.02em;max-width:none}
.poly{position:relative;max-width:1180px;margin:0 auto;display:grid;grid-template-columns:240px 1fr 240px;grid-template-rows:auto auto;gap:24px clamp(24px,3vw,56px);align-items:center;z-index:2}
.poly__txt{grid-column:2;grid-row:1/3;text-align:center;display:flex;flex-direction:column;align-items:center;gap:0;padding:8px 0;position:relative;z-index:3}
.poly__txt .bt--pill{margin-top:14px}
.pl{position:relative;width:100%;background:var(--cream);padding:12px 12px 16px;border:1.5px solid var(--ink);transform:rotate(var(--rot));box-shadow:0 10px 0 -1px var(--ink),0 22px 40px -18px #2a0e1a99;transition:transform .4s cubic-bezier(.2,.7,.2,1);display:block;color:var(--ink)}
.pl--0{grid-column:1;grid-row:1;align-self:end;margin-bottom:8px}
.pl--1{grid-column:1;grid-row:2;align-self:start;margin-top:8px}
.pl--2{grid-column:3;grid-row:1/3;align-self:center}
.pl:hover{transform:rotate(calc(var(--rot) * .4)) translateY(-6px) scale(1.02);z-index:9}
.pl__tape{position:absolute;top:-14px;left:50%;transform:translateX(-50%) rotate(-3deg);width:78px;height:22px;background:#f7d04ecc;border:1.5px solid var(--ink)}
.pl__img{display:block;aspect-ratio:1/1;background:
  repeating-linear-gradient(45deg, var(--swa) 0 14px, var(--swb) 14px 28px),
  conic-gradient(from 0deg at 50% 50%, var(--swa), var(--swb), var(--swa));
  border:1.5px solid var(--ink);position:relative;overflow:hidden;border-radius:6px}
.pl__loop{position:absolute;left:50%;top:50%;width:46%;height:46%;transform:translate(-50%,-50%);border-radius:50%;border:7px solid var(--cream);border-top-color:transparent;border-right-color:transparent;animation:loop 18s linear infinite;opacity:.9;mix-blend-mode:overlay}
@keyframes loop{to{transform:translate(-50%,-50%) rotate(-360deg)}}
.pl__cap{display:block;margin-top:14px;font:italic 600 18px/1.15 'Fraunces','Fraunces-fb',serif;font-variation-settings:"opsz" 144;text-align:center;color:var(--ink)}
.pl__sub{display:block;margin-top:6px;font:italic 500 13px/1.2 'Fraunces','Fraunces-fb',serif;text-align:center;color:var(--berry);opacity:.78;letter-spacing:.01em}
.poly__a{position:absolute;pointer-events:none;color:var(--berry);z-index:1}
.poly__a svg{width:100%;height:100%;display:block}
.poly__a--l{top:18%;left:20%;width:140px;height:60px;transform:rotate(-4deg)}
.poly__a--r{top:62%;right:20%;width:140px;height:60px;transform:rotate(4deg)}
/* ===== GINGHAM BAND ===== */
.band{position:relative;height:78px;background:
  conic-gradient(var(--cherry) 25%, var(--rose-mid) 0 50%, var(--cherry) 0 75%, var(--rose-mid) 0) 0 0/36px 36px;
  overflow:hidden;border-block:2px solid var(--ink)}
.band__inner{position:absolute;inset:0;display:flex;gap:36px;align-items:center;white-space:nowrap;font:600 18px/1 'Fraunces','Fraunces-fb',serif;font-variation-settings:"opsz" 144;color:var(--cream);text-transform:lowercase;letter-spacing:.04em;animation:tk 28s linear infinite;width:max-content;padding-inline:36px}
.band__inner span{display:inline-flex;align-items:center;gap:36px}
.band__inner span:nth-child(odd){font-size:24px;color:var(--cream)}
/* ===== DIARY ===== */
.dy{padding:88px clamp(20px,4vw,52px) 96px}
.dy__l{display:grid;grid-template-columns:repeat(3,1fr);gap:28px;max-width:1180px;margin:0 auto}
.pe{position:relative;background:var(--cream);border:1.5px solid var(--ink);border-radius:22px;overflow:hidden;box-shadow:0 8px 0 -1px var(--ink);transition:transform .4s cubic-bezier(.2,.7,.2,1)}
.pe:nth-child(even){transform:translateY(14px)}
.pe:hover{transform:translateY(-4px)}
.pe:nth-child(even):hover{transform:translateY(10px)}
.pe__lk{display:flex;flex-direction:column;height:100%}
.pe__sw{aspect-ratio:5/4;background:
  repeating-linear-gradient(-45deg, var(--swa) 0 16px, var(--swb) 16px 32px);
  position:relative;border-bottom:1.5px solid var(--ink);overflow:hidden}
.pe__loop{position:absolute;left:50%;top:50%;width:42%;height:42%;transform:translate(-50%,-50%);border-radius:50%;border:6px solid var(--cream);border-top-color:transparent;border-left-color:transparent;animation:loop 18s linear infinite;mix-blend-mode:overlay}
.pe__bd{padding:26px 24px 28px;display:flex;flex-direction:column;gap:10px;flex:1}
.pe__cat{font:500 10px/1 'DM Mono','DM-Mono-fb',monospace;letter-spacing:.28em;text-transform:lowercase;color:var(--acc);filter:brightness(.7) saturate(1.4)}
.pe__t{font:italic 600 24px/1.15 'Fraunces','Fraunces-fb',serif;font-variation-settings:"opsz" 144;color:var(--berry);letter-spacing:-.012em}
.pe__d{font-size:14px;line-height:1.55;color:#2a0e1ab0;flex:1}
.pe__m{display:flex;align-items:center;gap:8px;font:500 10px/1 'DM Mono','DM-Mono-fb',monospace;letter-spacing:.22em;text-transform:lowercase;color:#2a0e1a99;flex-wrap:wrap;margin-top:auto;padding-top:8px}
.pe__sk{margin-left:auto;background:var(--acc);color:var(--cream);padding:5px 9px;border-radius:999px;border:1px solid var(--ink);font-size:9px}
/* ===== ABOUT ===== */
.ab{padding:96px clamp(20px,4vw,52px);background:
  conic-gradient(var(--gingham-b) 25%, var(--gingham-a) 0 50%, var(--gingham-b) 0 75%, var(--gingham-a) 0) 0 0/52px 52px;
  position:relative;border-block:2px solid var(--ink)}
.ab__card{max-width:760px;margin:0 auto;padding:56px clamp(28px,4vw,72px);background:var(--cream);border:1.5px solid var(--ink);border-radius:24px;box-shadow:0 12px 0 -1px var(--ink);text-align:center;display:flex;flex-direction:column;gap:18px;align-items:center}
.ab__t{font:600 clamp(34px,4.6vw,60px)/1.05 'Fraunces','Fraunces-fb',serif;font-variation-settings:"opsz" 144;color:var(--berry);letter-spacing:-.015em}
.ab__b{font-size:16px;line-height:1.65;color:#2a0e1ac0;max-width:580px}
.ab__sig{font:italic 500 14px/1 'Fraunces','Fraunces-fb',serif;color:var(--cherry);margin-top:6px}
.ab__sticker{position:absolute;top:8%;right:6%;width:108px;height:108px;display:grid;place-items:center;text-align:center;background:var(--butter);color:var(--ink);font:500 10px/1.2 'DM Mono','DM-Mono-fb',monospace;letter-spacing:.22em;text-transform:lowercase;border-radius:50%;border:1.5px solid var(--ink);box-shadow:0 6px 0 -1px var(--ink);transform:rotate(12deg);animation:wobble 6s ease-in-out infinite}
.ab__sticker b{font-family:'Fraunces','Fraunces-fb',serif;font-style:italic;font-size:24px;letter-spacing:0;color:var(--cherry);display:block;margin-top:4px}
/* ===== CLUB ===== */
.cl{padding:96px clamp(20px,4vw,52px)}
.cl__card{max-width:980px;margin:0 auto;padding:64px clamp(28px,4vw,80px);background:var(--rose-hot);color:var(--cream);border-radius:28px;border:1.5px solid var(--ink);text-align:center;position:relative;overflow:hidden;box-shadow:0 14px 0 -1px var(--berry)}
.cl__card::before{content:"";position:absolute;inset:14px;border:1.5px dashed #fff8;border-radius:18px;pointer-events:none}
.cl__t{font:600 clamp(36px,5vw,72px)/1.03 'Fraunces','Fraunces-fb',serif;font-variation-settings:"opsz" 144;letter-spacing:-.018em;margin:14px 0 10px}
.cl__d{font-size:17px;line-height:1.55;max-width:520px;margin:0 auto 28px;color:#fff}
.cl__f{display:flex;gap:10px;justify-content:center;flex-wrap:wrap;align-items:center}
.cl__field{display:inline-flex;background:var(--cream);border-radius:999px;padding:0 6px 0 18px;border:1.5px solid var(--ink);height:50px;min-width:300px;align-items:center}
.cl__field input{height:100%;width:240px;color:var(--ink);padding:0 6px;font:400 14px/1 'Fraunces','Fraunces-fb',serif}
.cl__field input::placeholder{color:#2a0e1a80;font-style:italic}
.cl .bt--cream{height:50px;padding:0 24px}
.cl__ok{font:italic 600 24px/1.2 'Fraunces','Fraunces-fb',serif;color:var(--cream);padding:18px 22px;background:#ffffff22;border-radius:14px;display:inline-block;border:1.5px dashed #fff9}
.cl__ok span{color:var(--butter);font-size:28px;margin-right:6px}
.cl__err{flex-basis:100%;color:var(--cream);background:var(--berry);padding:8px 14px;border-radius:999px;font:500 11px/1 'DM Mono','DM-Mono-fb',monospace;letter-spacing:.22em;text-transform:lowercase;display:inline-block;margin-top:8px}
.cl__count{margin-top:22px;font:500 11px/1 'DM Mono','DM-Mono-fb',monospace;letter-spacing:.28em;text-transform:lowercase;color:#fff}
.cl__count b{color:#fff;font-family:'Fraunces','Fraunces-fb',serif;font-style:italic;font-weight:700;font-size:18px;letter-spacing:0;font-variant-numeric:tabular-nums;margin-right:4px;text-decoration:underline;text-decoration-color:var(--butter);text-decoration-thickness:2px;text-underline-offset:3px}
/* ===== POST PAGE ===== */
.ar{max-width:760px;margin:24px auto 48px;padding:0 clamp(20px,4vw,40px)}
.ar__h{text-align:center;padding:48px 0 32px;display:flex;flex-direction:column;align-items:center;gap:14px}
.ar__cat{display:inline-flex;align-items:center;gap:8px;background:var(--rose);color:var(--cherry);padding:6px 14px;border-radius:999px;border:1px solid var(--ink);font:500 11px/1 'DM Mono','DM-Mono-fb',monospace;letter-spacing:.22em;text-transform:lowercase}
.ar__cat span{color:var(--rose-hot);font-size:14px}
.ar__t{font:600 clamp(40px,5.6vw,72px)/1.02 'Fraunces','Fraunces-fb',serif;font-variation-settings:"opsz" 144;color:var(--berry);letter-spacing:-.018em}
.ar__d{font-size:18px;line-height:1.5;color:#2a0e1ab0;max-width:560px;font-style:italic}
.ar__m{font:500 11px/1 'DM Mono','DM-Mono-fb',monospace;letter-spacing:.22em;text-transform:lowercase;color:#2a0e1aa0;display:flex;gap:8px;align-items:center;flex-wrap:wrap;justify-content:center}
.ar__m em{color:var(--cherry);font-style:italic;font-family:'Fraunces','Fraunces-fb',serif;font-size:13px;letter-spacing:.04em;text-transform:none}
.ar__hero{position:relative;aspect-ratio:2/1;border:1.5px solid var(--ink);border-radius:18px;overflow:hidden;margin-bottom:48px;box-shadow:0 12px 0 -1px var(--ink)}
.ar__sw{position:absolute;inset:0;background:
  repeating-linear-gradient(45deg, var(--swa) 0 24px, var(--swb) 24px 48px)}
.ar__loop{position:absolute;left:50%;top:50%;width:30%;aspect-ratio:1;transform:translate(-50%,-50%);border-radius:50%;border:10px solid var(--cream);border-top-color:transparent;border-right-color:transparent;animation:loop 20s linear infinite;mix-blend-mode:overlay}
.ar__sk{position:absolute;top:18px;right:18px;background:var(--cream);color:var(--acc);padding:8px 14px;border-radius:999px;border:1.5px solid var(--ink);font:500 10px/1 'DM Mono','DM-Mono-fb',monospace;letter-spacing:.22em;text-transform:lowercase;transform:rotate(6deg)}
.ar__body{font-size:18px;line-height:1.75;color:#2a0e1ad0;font-family:'Fraunces','Fraunces-fb',serif}
.ar__body p{margin-bottom:1.2em}
.ar__body p:first-child::first-letter{font-size:64px;line-height:.95;float:left;padding:6px 12px 0 0;color:var(--rose-hot);font-style:italic;font-weight:600}
.ar__body strong{color:var(--cherry)}
.ar__sig{margin-top:40px;text-align:center;font:italic 500 14px/1 'Fraunces','Fraunces-fb',serif;color:var(--cherry)}
/* related */
.rl{padding:64px clamp(20px,4vw,52px);background:var(--cream-deep);border-block:2px solid var(--ink)}
.rl__l{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;max-width:1180px;margin:28px auto 0}
.rl__c{background:var(--cream);border:1.5px solid var(--ink);border-radius:18px;overflow:hidden;box-shadow:0 6px 0 -1px var(--ink);transition:transform .35s cubic-bezier(.2,.7,.2,1)}
.rl__c:hover{transform:translateY(-4px)}
.rl__c a{display:flex;flex-direction:column}
.rl__sw{aspect-ratio:5/3;background:repeating-linear-gradient(-45deg, var(--swa) 0 18px, var(--swb) 18px 36px);border-bottom:1.5px solid var(--ink)}
.rl__cat{padding:16px 20px 0;font:500 10px/1 'DM Mono','DM-Mono-fb',monospace;letter-spacing:.22em;text-transform:lowercase;color:var(--acc);filter:brightness(.7) saturate(1.4)}
.rl__t{padding:6px 20px 0;font:italic 600 20px/1.2 'Fraunces','Fraunces-fb',serif;color:var(--berry)}
.rl__d{padding:8px 20px 20px;font-size:13px;color:#2a0e1ab0;line-height:1.5}
/* ===== COMMENTS ===== */
.cm{max-width:760px;margin:0 auto;padding:64px clamp(20px,4vw,40px) 96px}
.cm__h{text-align:center;display:flex;flex-direction:column;align-items:center;gap:12px;margin-bottom:32px}
.cm__t{font:600 clamp(32px,4.2vw,56px)/1.05 'Fraunces','Fraunces-fb',serif;font-variation-settings:"opsz" 144;color:var(--berry);letter-spacing:-.015em}
.cm__t em{color:var(--rose-hot);font-style:italic}
.cm__ok{background:var(--rose);color:var(--berry);padding:14px 18px;border-radius:14px;border:1.5px solid var(--ink);font:italic 500 16px/1 'Fraunces','Fraunces-fb',serif;text-align:center;margin-bottom:24px}
.cm__f{background:var(--cream);border:1.5px solid var(--ink);border-radius:20px;padding:28px clamp(20px,3vw,32px);box-shadow:0 8px 0 -1px var(--ink);display:flex;flex-direction:column;gap:16px;margin-bottom:40px}
.cm__row{display:block}
.cm__field{display:block}
.cm__lbl{display:block;font:500 10px/1 'DM Mono','DM-Mono-fb',monospace;letter-spacing:.24em;text-transform:lowercase;color:var(--cherry);margin-bottom:8px}
.cm__field input,.cm__field textarea{width:100%;background:var(--cream-deep);border:1.5px solid var(--ink);border-radius:12px;padding:14px 16px;font:400 15px/1.45 'Fraunces','Fraunces-fb',serif;color:var(--ink);resize:vertical;transition:background .25s,box-shadow .25s}
.cm__field input:focus,.cm__field textarea:focus{outline:none;background:var(--cream);box-shadow:0 0 0 3px var(--rose-mid)}
.cm__field input::placeholder,.cm__field textarea::placeholder{color:#2a0e1a80;font-style:italic}
.cm__hp{position:absolute!important;left:-9999px!important;width:1px!important;height:1px!important;opacity:0!important}
.cm__err{background:var(--berry);color:var(--cream);padding:10px 14px;border-radius:999px;font:500 11px/1 'DM Mono','DM-Mono-fb',monospace;letter-spacing:.22em;text-transform:lowercase;align-self:flex-start}
.cm__f .bt{align-self:flex-start;margin-top:4px}
.cm__l{display:flex;flex-direction:column;gap:14px}
.cm__empty{padding:28px;text-align:center;background:var(--rose);border:1.5px dashed var(--ink);border-radius:18px;font:italic 500 16px/1 'Fraunces','Fraunces-fb',serif;color:var(--cherry)}
.cm__i{padding:22px 24px;background:var(--cream);border:1.5px solid var(--ink);border-radius:18px;box-shadow:0 4px 0 -1px var(--ink)}
.cm__a{font:italic 600 18px/1.1 'Fraunces','Fraunces-fb',serif;color:var(--berry);margin-bottom:6px;display:flex;justify-content:space-between;align-items:baseline;gap:12px;flex-wrap:wrap}
.cm__a span{font:500 10px/1 'DM Mono','DM-Mono-fb',monospace;letter-spacing:.22em;text-transform:lowercase;color:#2a0e1a90;font-style:normal}
.cm__b{font-size:15px;line-height:1.6;color:#2a0e1acc;white-space:pre-line}
/* 404 */
.er{padding:120px clamp(20px,4vw,40px);text-align:center}
.er__c{max-width:560px;margin:0 auto;display:flex;flex-direction:column;gap:16px;align-items:center}
.er__t{font:600 clamp(48px,7vw,96px)/1 'Fraunces','Fraunces-fb',serif;color:var(--berry)}
.er__t em{color:var(--rose-hot);font-style:italic}
.er__d{font-size:17px;line-height:1.55;color:#2a0e1ab0}
/* ===== FOOTER ===== */
.ft{padding:80px clamp(20px,4vw,52px) 40px;background:var(--ink);color:var(--cream);position:relative;overflow:hidden}
.ft__top{position:absolute;left:0;right:0;top:0;height:24px;background:var(--cream);-webkit-mask:radial-gradient(circle 12px at 12px 0, #000 99%, #0000 101%) 0 0/24px 24px repeat-x;mask:radial-gradient(circle 12px at 12px 0, #000 99%, #0000 101%) 0 0/24px 24px repeat-x;transform:translateY(-1px)}
.ft__wm{position:absolute;left:-.04em;bottom:-.18em;font:italic 600 clamp(140px,22vw,360px)/.85 'Fraunces','Fraunces-fb',serif;font-variation-settings:"opsz" 144;color:#fff3e90f;pointer-events:none;letter-spacing:-.04em}
.ft__grid{position:relative;z-index:2;display:grid;grid-template-columns:repeat(4,1fr);gap:36px;max-width:1180px;margin:0 auto;padding-top:24px}
.ft__h{font:500 10px/1 'DM Mono','DM-Mono-fb',monospace;letter-spacing:.32em;text-transform:lowercase;color:var(--butter);margin-bottom:14px}
.ft__grid a{display:block;font:400 14px/1 'Fraunces','Fraunces-fb',serif;margin-bottom:10px;color:#fff3e9cc;transition:color .25s,padding .3s}
.ft__grid a:hover{color:var(--butter);padding-left:6px}
.ft__note{font-size:14px;line-height:1.55;color:#fff3e9aa;max-width:240px}
.ft__base{position:relative;z-index:2;max-width:1180px;margin:56px auto 0;padding-top:22px;border-top:1px solid #fff3e922;display:flex;justify-content:space-between;gap:14px;flex-wrap:wrap;font:500 10px/1 'DM Mono','DM-Mono-fb',monospace;letter-spacing:.22em;text-transform:lowercase;color:#fff3e988}
/* ===== REVEAL ===== */
[data-reveal]{opacity:0;transform:translateY(14px);transition:opacity .8s cubic-bezier(.2,.7,.2,1),transform .8s cubic-bezier(.2,.7,.2,1)}
[data-reveal].rv{opacity:1;transform:none}
/* ===== RESPONSIVE ===== */
@media (max-width:1000px){
.cats__l{grid-template-columns:repeat(3,1fr)}
.cats__l li:nth-child(n+4){grid-column:span 1}
.dy__l,.rl__l{grid-template-columns:repeat(2,1fr)}
.ft__grid{grid-template-columns:repeat(2,1fr)}
.poly{min-height:780px}
.poly{min-height:auto;display:flex;flex-direction:column;align-items:center;gap:24px}
.poly__txt{position:static;transform:none;max-width:100%;order:1;padding:0}
.pl{position:relative;top:auto!important;left:auto!important;width:auto;display:block;margin:8px auto;max-width:300px;transform:rotate(var(--rot));order:2}
.pl--0{order:0}
.poly__a{display:none}
.ft2__t{font-size:clamp(28px,5.4vw,40px)}
.fs__l{grid-template-columns:1fr;gap:48px}
.fs__i::before{display:none}
.fs__i:not(:last-child)::after{content:"";display:block;width:140px;height:1px;border-top:1px dashed #2a0e1a26;margin:24px auto 0}
}
@media (max-width:680px){
.nv{grid-template-columns:auto 1fr auto;padding-bottom:28px}
.nv__l,.nv__r{gap:14px}
.nv__l .nv__lnk:nth-child(n+2),.nv__r .nv__lnk{display:none}
.nv__r .nv__sr{display:grid}
.cats__l{grid-template-columns:repeat(2,1fr)}
.dy__l,.rl__l{grid-template-columns:1fr;gap:20px}
.pe:nth-child(even){transform:none}
.pe:nth-child(even):hover{transform:translateY(-4px)}
.ft__grid{grid-template-columns:1fr;gap:28px}
.hr__title,.sx__t,.ft2__t,.cl__t,.ar__t,.cm__t{font-size:clamp(36px,9vw,52px)}
.ab__sticker{top:auto;bottom:6%;right:6%;width:88px;height:88px}
.cl__field{min-width:0;width:100%}
.cl__field input{width:100%}
.cl .bt--cream{width:100%}
}
@media (prefers-reduced-motion:reduce){
*,*::before,*::after{animation-duration:.001ms!important;animation-iteration-count:1!important;transition-duration:.001ms!important}
}
