:root{--paper:oklch(97.5% 0.012 85);--paper-raised:oklch(99% 0.008 85);--ink:oklch(22% 0.02 60);--ink-soft:oklch(45% 0.02 60);--ink-faint:oklch(50% 0.02 60);--line:oklch(88% 0.015 75);--accent:oklch(52% 0.17 38);--accent-soft:oklch(94% 0.05 45);--accent-ink:oklch(99% 0.01 60);--good:oklch(58% 0.13 150);--danger:oklch(55% 0.19 25);--text-sm:0.85rem;--text-base:clamp(1rem,0.96rem + 0.2vw,1.08rem);--text-lg:clamp(1.2rem,1.05rem + 0.6vw,1.5rem);--text-xl:clamp(1.6rem,1.2rem + 1.6vw,2.4rem);--text-display:clamp(2.4rem,1.4rem + 4vw,4.5rem);--space-1:0.5rem;--space-2:0.875rem;--space-3:1.5rem;--space-4:2.5rem;--space-5:4rem;--radius:14px;--radius-lg:22px;--shadow:0 1px 2px oklch(40% 0.02 60/0.06),0 8px 24px oklch(40% 0.02 60/0.08);--shadow-lg:0 2px 4px oklch(40% 0.02 60/0.08),0 18px 48px oklch(40% 0.02 60/0.12);--ease:cubic-bezier(0.16,1,0.3,1);--serif:"Iowan Old Style","Palatino Linotype","Georgia",serif;--sans:ui-sans-serif,system-ui,-apple-system,"Segoe UI",Roboto,sans-serif}*{box-sizing:border-box;margin:0;padding:0}html{-webkit-text-size-adjust:100%}body{font-family:var(--sans);font-size:var(--text-base);line-height:1.55;color:var(--ink);background:var(--paper);background-image:radial-gradient(oklch(80% .02 75/.4) .5px,transparent 0);background-size:22px 22px;-webkit-font-smoothing:antialiased}h1,h2,h3{font-family:var(--serif);font-weight:600;line-height:1.05;letter-spacing:-.01em}a{color:inherit;text-decoration:none}button,input,select,textarea{font:inherit;color:inherit}:focus-visible{outline:2.5px solid var(--accent);outline-offset:2px;border-radius:6px}.skip-link{position:absolute;left:var(--space-2);top:-100%;z-index:100;padding:.6em 1em;border-radius:var(--radius);background:var(--ink);color:var(--paper-raised);font-weight:600;transition:top .15s var(--ease)}.skip-link:focus{top:var(--space-2)}@media (prefers-reduced-motion:reduce){*{animation-duration:.01ms!important;transition-duration:.01ms!important}}.shell{min-height:100dvh;display:flex;flex-direction:column}.topbar{display:flex;align-items:center;justify-content:space-between;gap:var(--space-3);padding:var(--space-2) var(--space-3);border-bottom:1px solid var(--line);background:var(--paper-raised);position:-webkit-sticky;position:sticky;top:0;z-index:10}.brand{font-family:var(--serif);font-size:var(--text-lg);font-weight:700;letter-spacing:-.02em}.brand span{color:var(--accent)}.topbar-right{display:flex;align-items:center;gap:var(--space-2);color:var(--ink-soft);font-size:var(--text-sm)}.content{width:min(1180px,100%);margin:0 auto;padding:var(--space-4) var(--space-3) var(--space-5);flex:1 1}.btn{display:inline-flex;align-items:center;justify-content:center;gap:.5em;padding:.62em 1.1em;border-radius:999px;border:1px solid transparent;background:var(--ink);color:var(--paper-raised);font-weight:600;cursor:pointer;transition:transform .18s var(--ease),box-shadow .18s var(--ease),background .18s var(--ease)}.btn:hover{transform:translateY(-1px);box-shadow:var(--shadow)}.btn:active{transform:translateY(0)}.btn--accent{background:var(--accent);color:var(--accent-ink)}.btn--ghost{background:transparent;border-color:var(--line);color:var(--ink)}.btn--ghost:hover{background:var(--paper-raised)}.btn--danger{background:transparent;border-color:color-mix(in oklch,var(--danger),transparent 55%);color:var(--danger)}.btn--sm{padding:.4em .8em;font-size:var(--text-sm)}.btn:disabled{opacity:.5;cursor:default;transform:none;box-shadow:none}.field{display:flex;flex-direction:column;gap:.35rem;margin-bottom:var(--space-2)}.field label{font-size:var(--text-sm);color:var(--ink-soft);font-weight:600}.input{padding:.7em .9em;border:1px solid var(--line);border-radius:var(--radius);background:var(--paper-raised);transition:border-color .18s var(--ease)}.input:focus{border-color:var(--accent)}.error-text{color:var(--danger);font-size:var(--text-sm)}.auth-wrap{display:grid;grid-template-columns:1.1fr 1fr;min-height:100dvh}.auth-hero{background:linear-gradient(150deg,var(--accent),oklch(48% .13 30));color:var(--accent-ink);padding:var(--space-5) var(--space-4);display:flex;flex-direction:column;justify-content:space-between}.auth-hero h1{font-size:var(--text-display);color:var(--accent-ink)}.auth-hero p{font-size:var(--text-lg);max-width:26ch;opacity:.92;margin-top:var(--space-2)}.auth-hero .tag{font-size:var(--text-sm);letter-spacing:.18em;text-transform:uppercase;opacity:.8}.auth-panel{display:flex;align-items:center;justify-content:center;padding:var(--space-4)}.auth-card{width:min(380px,100%)}.auth-card h2{font-size:var(--text-xl);margin-bottom:var(--space-1)}.auth-card .sub{color:var(--ink-soft);margin-bottom:var(--space-3)}.auth-toggle{margin-top:var(--space-2);font-size:var(--text-sm);color:var(--ink-soft);background:none;border:none;cursor:pointer;text-decoration:underline}@media (max-width:760px){.auth-wrap{grid-template-columns:1fr}.auth-hero{min-height:38vh}}.page-head{display:flex;align-items:flex-end;justify-content:space-between;gap:var(--space-3);margin-bottom:var(--space-4);flex-wrap:wrap}.page-head h1{font-size:var(--text-xl)}.page-head .lead{color:var(--ink-soft)}.eyebrow{font-size:var(--text-sm);letter-spacing:.16em;text-transform:uppercase;color:var(--accent);font-weight:700}.bento{display:grid;grid-template-columns:repeat(auto-fill,minmax(230px,1fr));grid-gap:var(--space-3);gap:var(--space-3)}.box-card{display:flex;flex-direction:column;gap:var(--space-1);padding:var(--space-3);border-radius:var(--radius-lg);background:var(--paper-raised);border:1px solid var(--line);box-shadow:var(--shadow);min-height:150px;transition:transform .2s var(--ease),box-shadow .2s var(--ease)}.box-card:hover{transform:translateY(-3px);box-shadow:var(--shadow-lg)}.box-card .code{font-size:var(--text-sm);color:var(--accent);font-weight:700;letter-spacing:.04em}.box-card h3{font-size:var(--text-lg)}.box-card .count{margin-top:auto;font-size:var(--text-sm);color:var(--ink-soft)}.box-card--add{align-items:center;justify-content:center;border-style:dashed;box-shadow:none;color:var(--ink-soft);background:transparent}.box-card--add:hover{color:var(--accent);border-color:var(--accent)}.section{margin-top:var(--space-5)}.section h2{font-size:var(--text-lg);margin-bottom:var(--space-2)}.game-list{display:flex;flex-direction:column;border:1px solid var(--line);border-radius:var(--radius-lg);overflow:hidden;background:var(--paper-raised)}.game-row{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-3);border-bottom:1px solid var(--line)}.game-row:last-child{border-bottom:none}.game-row .meta{color:var(--ink-faint);font-size:var(--text-sm)}.game-row .grow{flex:1 1;min-width:0}.game-row strong{font-weight:600}.game-thumb{width:42px;height:42px;border-radius:8px;object-fit:cover;background:var(--accent-soft);flex-shrink:0}.game-meta{display:flex;flex-wrap:wrap;gap:var(--space-2);margin-top:.2rem}.game-meta .link{color:var(--accent);text-decoration:none}.game-meta .link:hover{text-decoration:underline}.game-row--edit{align-items:flex-start;flex-wrap:wrap}.game-edit-fields{display:flex;flex-wrap:wrap;gap:var(--space-1)}.game-edit-fields .input{flex:1 1;min-width:90px}.game-edit-fields .input:first-child{flex:2 1;min-width:140px}.game-edit-fields .game-edit-notes{flex:1 0 100%;min-width:100%}.game-notes{margin-top:.2rem;white-space:pre-wrap}.toolbar{display:flex;gap:var(--space-2);align-items:center;margin-bottom:var(--space-2);flex-wrap:wrap}.toolbar .input{flex:1 1;min-width:180px}.empty{padding:var(--space-4);text-align:center;color:var(--ink-soft);border:1px dashed var(--line);border-radius:var(--radius-lg)}.panel{padding:var(--space-3);border:1px solid var(--line);border-radius:var(--radius-lg);background:var(--paper-raised);margin-bottom:var(--space-3)}.row-actions{display:flex;gap:var(--space-1)}.crumb{color:var(--ink-soft);font-size:var(--text-sm);margin-bottom:var(--space-1)}.crumb a:hover{color:var(--accent)}.suggestions{display:flex;flex-direction:column;gap:4px;margin-top:var(--space-1)}.suggestion{text-align:left;padding:.5em .8em;border:1px solid var(--line);border-radius:var(--radius);background:var(--paper);cursor:pointer}.suggestion:hover{border-color:var(--accent)}.lp-header{width:min(1180px,100%);margin:0 auto;padding:var(--space-3);justify-content:space-between}.lp-header,.lp-nav{display:flex;align-items:center;gap:var(--space-3)}.lp-nav{font-size:var(--text-sm)}.lp-nav a{color:var(--ink-soft)}.lp-nav a:hover{color:var(--accent)}@media (max-width:620px){.lp-nav .hide-sm{display:none}}.lp-hero{width:min(1180px,100%);margin:0 auto;padding:var(--space-4) var(--space-3) var(--space-5);display:grid;grid-template-columns:1.05fr .95fr;grid-gap:var(--space-4);gap:var(--space-4);align-items:center}.lp-hero h1{font-size:var(--text-display);max-width:13ch}.lp-hero .lead{font-size:var(--text-lg);color:var(--ink-soft);max-width:44ch;margin-top:var(--space-2)}.lp-cta{display:flex;flex-wrap:wrap;gap:var(--space-2);margin-top:var(--space-3)}@media (max-width:860px){.lp-hero{grid-template-columns:1fr}}.lp-stack{position:relative;height:340px}.lp-tile{position:absolute;width:62%;padding:var(--space-3);border-radius:var(--radius-lg);background:var(--paper-raised);border:1px solid var(--line);box-shadow:var(--shadow-lg)}.lp-tile .code{color:var(--accent);font-weight:700;font-size:var(--text-sm)}.lp-tile h3{font-size:var(--text-lg);margin-top:4px}.lp-tile .count{color:var(--ink-faint);font-size:var(--text-sm);margin-top:var(--space-2)}.lp-tile:first-child{top:0;left:0;transform:rotate(-4deg)}.lp-tile:nth-child(2){top:90px;right:0;transform:rotate(3deg);background:var(--accent);color:var(--accent-ink);border-color:transparent}.lp-tile:nth-child(2) .code,.lp-tile:nth-child(2) .count{color:var(--accent-ink);opacity:.85}.lp-tile:nth-child(3){bottom:0;left:12%;transform:rotate(-1deg)}.lp-section{width:min(1180px,100%);margin:0 auto;padding:var(--space-5) var(--space-3)}.lp-section>h2{font-size:var(--text-xl);margin-bottom:var(--space-3);max-width:18ch}.lp-steps{display:grid;grid-template-columns:repeat(3,1fr);grid-gap:var(--space-3);gap:var(--space-3);list-style:none}@media (max-width:760px){.lp-steps{grid-template-columns:1fr}}.lp-step{padding:var(--space-3);position:relative}.lp-step+.lp-step:before{content:"";position:absolute;left:-1px;top:var(--space-3);bottom:var(--space-3);border-left:1px dashed var(--line)}@media (max-width:760px){.lp-step+.lp-step:before{display:none}}.lp-step .num{display:inline-flex;align-items:center;justify-content:center;width:2.4rem;height:2.4rem;border-radius:999px;background:var(--accent-soft);color:var(--accent);font-family:var(--serif);font-weight:700;font-size:var(--text-lg);margin-bottom:var(--space-2)}.lp-step h3{font-size:var(--text-lg);margin-bottom:.4rem}.lp-step p{color:var(--ink-soft)}.lp-features{display:grid;grid-template-columns:repeat(3,1fr);grid-gap:var(--space-3);gap:var(--space-3)}@media (max-width:860px){.lp-features{grid-template-columns:1fr 1fr}}@media (max-width:520px){.lp-features{grid-template-columns:1fr}}.lp-feature{padding:var(--space-3);border-radius:var(--radius-lg);border:1px solid var(--line);background:var(--paper-raised);box-shadow:var(--shadow);transition:transform .2s var(--ease),box-shadow .2s var(--ease)}.lp-feature:hover{transform:translateY(-3px);box-shadow:var(--shadow-lg)}.lp-feature:hover .ico{background:var(--accent);color:var(--accent-ink)}.lp-feature .ico{display:inline-flex;align-items:center;justify-content:center;width:3rem;height:3rem;border-radius:14px;background:var(--accent-soft);color:var(--accent);transition:background .2s var(--ease),color .2s var(--ease)}.lp-feature h3{font-size:var(--text-lg);margin:var(--space-1) 0 .3rem}.lp-feature p{color:var(--ink-soft);font-size:.96rem}.lp-feature--wide{background:var(--ink);color:var(--paper-raised);border-color:transparent}.lp-feature--wide p{color:oklch(85% .02 75)}.lp-band{width:min(1180px,100%);margin:0 auto var(--space-5);padding:var(--space-5) var(--space-4);border-radius:var(--radius-lg);text-align:center;background:linear-gradient(150deg,var(--accent),oklch(48% .13 30))}.lp-band,.lp-band h2{color:var(--accent-ink)}.lp-band h2{font-size:var(--text-xl);max-width:20ch;margin:0 auto var(--space-2)}.lp-band .btn{background:var(--accent-ink);color:var(--accent)}.lp-footer{border-top:1px solid var(--line);padding:var(--space-3);text-align:center;color:var(--ink-faint);font-size:var(--text-sm)}.lp-hero-copy{animation:lp-rise .7s var(--ease) both}.lp-section>.eyebrow{margin-bottom:.4rem}.lp-trust{display:flex;flex-wrap:wrap;gap:.5rem 1.1rem;margin-top:var(--space-3);list-style:none;font-size:var(--text-sm);color:var(--ink-soft)}.lp-trust li{display:inline-flex;align-items:center;gap:.4rem}.lp-trust svg{color:var(--good)}.lp-stack{animation:lp-rise .7s var(--ease) .12s both}.lp-tile{animation:lp-float 7s var(--ease) infinite}.lp-tile:nth-child(2){animation-delay:-2.3s}.lp-tile:nth-child(3){animation-delay:-4.6s}@keyframes lp-rise{0%{opacity:0;transform:translateY(18px)}to{opacity:1;transform:none}}@keyframes lp-float{0%,to{translate:0 0}50%{translate:0 -10px}}@supports (animation-timeline:view()){@media (prefers-reduced-motion:no-preference){.reveal{animation:lp-rise linear both;animation-timeline:view();animation-range:entry 0 cover 22%}}}@media (prefers-reduced-motion:reduce){.lp-hero-copy,.lp-stack,.lp-tile{animation:none}}.lp-feature--wide .ico{background:oklch(100% 0 0/.12);color:var(--accent-ink)}.lp-feature--wide:hover .ico{background:var(--accent);color:var(--accent-ink)}.lp-faq{display:flex;flex-direction:column;gap:var(--space-1)}.lp-faq-item{border:1px solid var(--line);border-radius:var(--radius);background:var(--paper-raised);overflow:hidden;transition:border-color .18s var(--ease),box-shadow .18s var(--ease)}.lp-faq-item[open]{border-color:color-mix(in oklch,var(--accent),transparent 55%);box-shadow:var(--shadow)}.lp-faq-item summary{display:flex;align-items:center;justify-content:space-between;gap:var(--space-2);padding:var(--space-2) var(--space-3);cursor:pointer;font-family:var(--serif);font-size:var(--text-lg);font-weight:600;line-height:1.25;list-style:none}.lp-faq-item summary::-webkit-details-marker{display:none}.lp-faq-item summary:hover{color:var(--accent)}.lp-faq-chev{flex-shrink:0;color:var(--ink-faint);transition:transform .22s var(--ease)}.lp-faq-item[open] .lp-faq-chev{transform:rotate(180deg);color:var(--accent)}.lp-faq-item>p{padding:0 var(--space-3) var(--space-3);color:var(--ink-soft)}.lp-band-sub{opacity:.92;margin-bottom:var(--space-3)}.lp-footer-links{margin-top:.5rem}.lp-footer a:hover{color:var(--accent)}.lang-switch{gap:1px;padding:2px;border:1px solid var(--line);background:var(--paper-raised)}.lang-opt,.lang-switch{display:inline-flex;align-items:center;border-radius:999px}.lang-opt{justify-content:center;min-width:1.6rem;min-height:1.6rem;padding:.35rem .55rem;font-size:.72rem;font-weight:700;letter-spacing:.04em;color:var(--ink-soft);transition:background .18s var(--ease),color .18s var(--ease)}.lang-opt:hover{color:var(--accent)}.lang-opt.is-active{background:var(--accent);color:var(--accent-ink)}.acct{position:relative}.acct-trigger{display:inline-flex;align-items:center;gap:.5rem;cursor:pointer;padding:.3rem .5rem .3rem .35rem;border:1px solid var(--line);border-radius:999px;background:var(--paper-raised);color:var(--ink);transition:border-color .18s var(--ease),box-shadow .18s var(--ease)}.acct-trigger:hover{border-color:var(--accent);box-shadow:var(--shadow)}.acct-avatar{display:inline-flex;align-items:center;justify-content:center;width:1.9rem;height:1.9rem;border-radius:999px;background:var(--accent);color:var(--accent-ink);font-weight:700;font-size:var(--text-sm)}.acct-email{max-width:16ch;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-size:var(--text-sm)}.acct-caret{color:var(--ink-faint);font-size:.7rem}@media (max-width:520px){.acct-email{display:none}}.acct-menu{position:absolute;right:0;top:calc(100% + .5rem);min-width:220px;z-index:20;background:var(--paper-raised);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow-lg);padding:.4rem;display:flex;flex-direction:column;gap:2px;animation:acct-pop .16s var(--ease)}@keyframes acct-pop{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:none}}.acct-item{display:flex;align-items:center;gap:.5rem;width:100%;text-align:left;padding:.55rem .7rem;border-radius:8px;font-size:var(--text-sm);color:var(--ink);background:none;border:none;cursor:pointer}.acct-item:hover{background:var(--accent-soft);color:var(--accent)}.acct-item--btn{color:var(--danger)}.acct-item--btn:hover{background:color-mix(in oklch,var(--danger),transparent 88%);color:var(--danger)}.acct-sep{height:1px;background:var(--line);margin:.3rem 0}.acct-badge{font-size:.65rem;font-weight:700;letter-spacing:.04em;text-transform:uppercase;background:var(--accent);color:var(--accent-ink);padding:.1rem .4rem;border-radius:999px}.settings-grid{display:grid;grid-template-columns:1fr 1fr;grid-gap:var(--space-3);gap:var(--space-3);align-items:start}@media (max-width:760px){.settings-grid{grid-template-columns:1fr}}.panel--danger{border-color:color-mix(in oklch,var(--danger),transparent 60%)}.danger-zone{flex-direction:column}.danger-row,.danger-zone{display:flex;gap:var(--space-2)}.danger-row{align-items:flex-start;justify-content:space-between;padding:var(--space-2) 0;border-bottom:1px solid var(--line);flex-wrap:wrap}.danger-row:last-child{border-bottom:none}.danger-row .meta{color:var(--ink-soft);font-size:var(--text-sm);margin-top:.2rem}.danger-delete{display:flex;gap:.5rem;flex-wrap:wrap}.danger-delete .input{padding:.4em .7em}.stat-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));grid-gap:var(--space-2);gap:var(--space-2)}.stat-card{display:flex;flex-direction:column;gap:.2rem;padding:var(--space-3);border-radius:var(--radius-lg);background:var(--paper-raised);border:1px solid var(--line);box-shadow:var(--shadow)}.stat-value{font-family:var(--serif);font-size:var(--text-xl);font-weight:700;color:var(--accent);line-height:1}.stat-label{font-size:var(--text-sm);color:var(--ink-soft);letter-spacing:.04em;text-transform:uppercase}.admin-table-wrap{overflow-x:auto;border:1px solid var(--line);border-radius:var(--radius-lg);background:var(--paper-raised)}.admin-table{width:100%;border-collapse:collapse;font-size:var(--text-sm)}.admin-table td,.admin-table th{padding:var(--space-2) var(--space-3);text-align:left;border-bottom:1px solid var(--line);white-space:nowrap}.admin-table th{color:var(--ink-soft);font-weight:600;font-size:var(--text-sm)}.admin-table tbody tr:last-child td{border-bottom:none}.admin-table tbody tr:hover{background:var(--paper)}.admin-table .num{text-align:right;font-feature-settings:"tnum";font-variant-numeric:tabular-nums}.tag-pill{display:inline-block;font-size:.7rem;padding:.12rem .5rem;border-radius:999px;background:var(--accent-soft);color:var(--ink-soft);margin-right:.3rem}.tag-pill--accent{background:var(--accent);color:var(--accent-ink)}.legal-top{width:min(820px,100%);margin:0 auto;padding:var(--space-3)}.legal{width:min(760px,100%);margin:0 auto;padding:var(--space-3) var(--space-3) var(--space-5)}.legal h1{font-size:var(--text-xl);margin-bottom:var(--space-1)}.legal .updated{color:var(--ink-faint);font-size:var(--text-sm);margin-bottom:var(--space-3)}.legal h2{font-size:var(--text-lg);margin:var(--space-4) 0 var(--space-1)}.legal h3{font-size:var(--text-base);font-weight:700;margin:var(--space-2) 0 .2rem}.legal li,.legal p{color:var(--ink-soft);margin-bottom:var(--space-2);line-height:1.65}.legal ul{padding-left:1.3rem;margin-bottom:var(--space-2)}.legal li{margin-bottom:.4rem}.legal a{color:var(--accent);text-decoration:underline}.legal .addr,.legal-notice{color:var(--ink)}.legal-notice{padding:var(--space-2) var(--space-3);margin-bottom:var(--space-3);border:1px solid color-mix(in oklch,var(--accent),transparent 55%);border-radius:var(--radius);background:var(--accent-soft);font-size:var(--text-sm)}