/* ============================================================
   skunk.to — components gallery
   Layout + component styles not already in styles.css
   ============================================================ */

/* ---- layout ---- */
.cx-wrap{display:grid;grid-template-columns:228px 1fr;gap:48px;
  max-width:var(--maxw);margin:0 auto;padding:48px var(--gut) 100px;align-items:start}
.cx-side{position:sticky;top:96px;display:flex;flex-direction:column;gap:2px}
.cx-side .cx-kicker{font-family:var(--mono);font-size:11px;letter-spacing:.12em;text-transform:uppercase;
  color:var(--text-mute);margin:18px 0 8px;padding-left:12px}
.cx-side a{padding:8px 12px;border-radius:var(--r-sm);color:var(--text-dim);font-size:14.5px;
  font-weight:500;transition:.15s;border-left:2px solid transparent}
.cx-side a:hover{color:var(--text);background:color-mix(in srgb,var(--brand) 10%,transparent)}
.cx-side a.active{color:var(--brand-300);border-left-color:var(--brand)}
.cx-main{min-width:0}
.cx-hero{margin-bottom:8px}
.cx-hero h1{font-size:clamp(32px,4.5vw,48px);font-weight:700;letter-spacing:-.03em;margin:0}
.cx-hero p{color:var(--text-dim);font-size:18px;margin:14px 0 0;max-width:54ch}

.cx-sec{padding-top:56px;scroll-margin-top:88px}
.cx-sec-head{display:flex;align-items:baseline;gap:12px;margin-bottom:24px;
  padding-bottom:14px;border-bottom:1px solid var(--line-soft)}
.cx-sec-head h2{font-size:24px;font-weight:700;letter-spacing:-.02em;margin:0}
.cx-sec-head .num{font-family:var(--mono);font-size:12px;color:var(--brand-300)}
.cx-sec-head .desc{margin-left:auto;font-size:13.5px;color:var(--text-mute);font-family:var(--mono)}

/* example cells */
.cx-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:16px}
.cx-cell{background:var(--surface);border:1px solid var(--line);border-radius:var(--r-lg);
  padding:24px;display:flex;flex-direction:column;gap:18px}
.cx-cell.span2{grid-column:span 2}
.cx-cell.full{grid-column:1/-1}
.cx-lab{font-family:var(--mono);font-size:11px;letter-spacing:.08em;text-transform:uppercase;color:var(--text-mute)}
.cx-row{display:flex;flex-wrap:wrap;gap:12px;align-items:center}
.cx-col{display:flex;flex-direction:column;gap:12px}
@media(max-width:880px){.cx-wrap{grid-template-columns:1fr;gap:0}.cx-side{display:none}}
@media(max-width:560px){
  .cx-wrap{padding:32px var(--gut) 80px}
  .cx-cell.span2,.cx-cell.full{grid-column:auto}   /* never span >1 in a single-column grid */
  .cx-grid{grid-template-columns:1fr}
  .cx-cell{padding:20px}
  .cx-hero h1{font-size:30px}
  .tbl{display:block;overflow-x:auto;white-space:nowrap}
  .seg{flex-wrap:wrap}
  .pager{flex-wrap:wrap}
  .steps{gap:4px}
  .mfa-row input{height:50px}
}

/* ---- foundations: swatches ---- */
.sw-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(120px,1fr));gap:12px}
.sw{border:1px solid var(--line);border-radius:var(--r);overflow:hidden;background:var(--bg-2)}
.sw .chip{height:62px;border-radius:0;border:none;display:block;width:100%}
.sw .meta{padding:10px 12px}
.sw .meta b{display:block;font-size:13px;font-weight:600}
.sw .meta span{font-family:var(--mono);font-size:11px;color:var(--text-mute)}

.type-row{display:flex;align-items:baseline;gap:18px;padding:14px 0;border-bottom:1px solid var(--line-soft)}
.type-row:last-child{border:none}
.type-row .tag{font-family:var(--mono);font-size:11px;color:var(--text-mute);width:128px;flex-shrink:0}
.type-row .sample{color:var(--text);line-height:1.1}

.token-row{display:flex;align-items:center;gap:16px;padding:10px 0;border-bottom:1px solid var(--line-soft)}
.token-row:last-child{border:none}
.token-row .swatch-r{background:var(--brand);height:40px;flex-shrink:0}
.token-row .bar{height:14px;background:color-mix(in srgb,var(--brand) 30%,transparent);border:1px solid var(--line)}
.token-row code{font-family:var(--mono);font-size:12px;color:var(--brand-300);width:84px;flex-shrink:0}

.icon-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(74px,1fr));gap:10px}
.icon-grid .ic{aspect-ratio:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;
  background:var(--bg-2);border:1px solid var(--line);border-radius:var(--r);color:var(--text-dim);transition:.15s}
.icon-grid .ic:hover{color:var(--brand-300);border-color:var(--brand)}
.icon-grid .ic svg{width:22px;height:22px}
.icon-grid .ic span{font-family:var(--mono);font-size:9.5px;color:var(--text-mute)}

/* ---- badges / tags / status ---- */
.badge2{display:inline-flex;align-items:center;gap:6px;font-family:var(--mono);font-size:12px;font-weight:500;
  padding:5px 11px;border-radius:var(--pill);white-space:nowrap}
.badge2 svg{width:13px;height:13px}
.b-purple{background:color-mix(in srgb,var(--brand) 16%,transparent);color:var(--brand-300);border:1px solid color-mix(in srgb,var(--brand) 35%,transparent)}
.b-green{background:rgba(58,214,160,.12);color:var(--ok);border:1px solid rgba(58,214,160,.32)}
.b-amber{background:rgba(245,185,69,.12);color:var(--warn);border:1px solid rgba(245,185,69,.32)}
.b-red{background:rgba(244,86,104,.12);color:#f45668;border:1px solid rgba(244,86,104,.32)}
.b-solid{background:var(--brand);color:var(--on-brand)}
.b-neutral{background:var(--surface-3);color:var(--text-dim);border:1px solid var(--line)}
.dot{width:8px;height:8px;border-radius:50%;display:inline-block}
.status{display:inline-flex;align-items:center;gap:8px;font-size:13.5px;color:var(--text-dim)}
.tag{display:inline-flex;align-items:center;gap:7px;background:var(--bg-2);border:1px solid var(--line);
  color:var(--text-dim);font-size:13px;padding:6px 8px 6px 12px;border-radius:var(--pill)}
.tag button{background:none;border:none;color:var(--text-mute);display:flex;padding:2px;border-radius:50%;cursor:pointer}
.tag button:hover{color:var(--text);background:var(--surface-3)}
.tag button svg{width:13px;height:13px}

/* ---- search input ---- */
.search{position:relative;display:flex}
.search svg{position:absolute;left:14px;top:50%;transform:translateY(-50%);width:17px;height:17px;color:var(--text-mute)}
.search .input{padding-left:42px}

/* ---- checkbox / radio ---- */
.opt{display:flex;align-items:center;gap:11px;cursor:pointer;font-size:14.5px;color:var(--text)}
.opt input{position:absolute;opacity:0;width:0;height:0}
.box{width:20px;height:20px;border-radius:6px;border:1.5px solid var(--line);background:var(--bg-2);
  display:grid;place-items:center;flex-shrink:0;transition:.15s;color:var(--on-brand)}
.box svg{width:13px;height:13px;opacity:0;transition:.15s}
.opt input:checked + .box{background:var(--brand);border-color:var(--brand)}
.opt input:checked + .box svg{opacity:1}
.opt input:focus-visible + .box{outline:2px solid var(--brand-300);outline-offset:2px}
.radio .box{border-radius:50%}
.radio .box::after{content:"";width:9px;height:9px;border-radius:50%;background:var(--on-brand);transform:scale(0);transition:.15s}
.radio input:checked + .box{background:var(--brand);border-color:var(--brand)}
.radio input:checked + .box::after{transform:scale(1)}

/* ---- segmented ---- */
.seg{display:inline-flex;gap:3px;padding:4px;background:var(--bg-2);border:1px solid var(--line);border-radius:var(--pill)}
.seg button{padding:8px 16px;border-radius:var(--pill);border:none;background:none;color:var(--text-dim);
  font-family:var(--sans);font-weight:600;font-size:14px;cursor:pointer;transition:.15s}
.seg button.on{background:var(--brand);color:var(--on-brand)}
.seg button:not(.on):hover{color:var(--text)}

/* ---- slider ---- */
.slider{width:100%;-webkit-appearance:none;appearance:none;height:6px;border-radius:var(--pill);
  background:var(--surface-3);outline:none}
.slider::-webkit-slider-thumb{-webkit-appearance:none;width:20px;height:20px;border-radius:50%;
  background:var(--brand);cursor:pointer;border:3px solid var(--bg-2);box-shadow:0 0 0 1px var(--brand)}
.slider::-moz-range-thumb{width:18px;height:18px;border-radius:50%;background:var(--brand);cursor:pointer;border:3px solid var(--bg-2)}

/* ---- alerts ---- */
.alert{display:flex;gap:13px;padding:15px 17px;border-radius:var(--r);border:1px solid var(--line);
  background:var(--bg-2);font-size:14.5px}
.alert svg{width:19px;height:19px;flex-shrink:0;margin-top:1px}
.alert .at{font-weight:600;margin:0 0 2px}
.alert .ab{margin:0;color:var(--text-dim);font-size:13.5px;line-height:1.5}
.alert.a-info{border-color:color-mix(in srgb,var(--brand) 40%,transparent);background:color-mix(in srgb,var(--brand) 8%,transparent)}
.alert.a-info svg{color:var(--brand-300)}
.alert.a-ok{border-color:rgba(58,214,160,.35);background:rgba(58,214,160,.07)}
.alert.a-ok svg{color:var(--ok)}
.alert.a-warn{border-color:rgba(245,185,69,.35);background:rgba(245,185,69,.07)}
.alert.a-warn svg{color:var(--warn)}
.alert.a-err{border-color:rgba(244,86,104,.35);background:rgba(244,86,104,.07)}
.alert.a-err svg{color:#f45668}

/* ---- tooltip ---- */
.tip{position:relative;display:inline-flex}
.tip .tip-b{position:absolute;bottom:calc(100% + 10px);left:50%;transform:translateX(-50%) translateY(4px);
  background:var(--surface-3);border:1px solid var(--line);color:var(--text);font-size:12.5px;
  padding:7px 11px;border-radius:8px;white-space:nowrap;opacity:0;pointer-events:none;transition:.18s;font-family:var(--mono)}
.tip .tip-b::after{content:"";position:absolute;top:100%;left:50%;transform:translateX(-50%);
  border:5px solid transparent;border-top-color:var(--surface-3)}
.tip:hover .tip-b{opacity:1;transform:translateX(-50%) translateY(0)}

/* ---- progress / meter ---- */
.prog{height:8px;border-radius:var(--pill);background:var(--surface-3);overflow:hidden}
.prog i{display:block;height:100%;background:var(--brand);border-radius:var(--pill)}
.meter-lab{display:flex;justify-content:space-between;font-family:var(--mono);font-size:11.5px;color:var(--text-mute);margin-bottom:7px}

/* ---- skeleton ---- */
.skel{background:linear-gradient(90deg,var(--surface-2) 25%,var(--surface-3) 50%,var(--surface-2) 75%);
  background-size:200% 100%;border-radius:8px;animation:shimmer 1.4s infinite}
@keyframes shimmer{from{background-position:200% 0}to{background-position:-200% 0}}

/* ---- breadcrumb / pagination ---- */
.crumbs{display:flex;align-items:center;gap:8px;font-size:14px;color:var(--text-mute);font-family:var(--mono)}
.crumbs a{color:var(--text-dim)}.crumbs a:hover{color:var(--brand-300)}
.crumbs .sep{opacity:.5}
.crumbs b{color:var(--text);font-weight:600}
.pager{display:flex;gap:6px}
.pager button{min-width:38px;height:38px;border-radius:var(--r-sm);border:1px solid var(--line);
  background:var(--bg-2);color:var(--text-dim);font-family:var(--mono);font-size:14px;cursor:pointer;transition:.15s}
.pager button:hover{color:var(--text);border-color:var(--brand)}
.pager button.on{background:var(--brand);color:var(--on-brand);border-color:var(--brand)}

/* ---- stat cards ---- */
.stat{background:var(--bg-2);border:1px solid var(--line);border-radius:var(--r);padding:18px}
.stat .sl{font-family:var(--mono);font-size:11px;text-transform:uppercase;letter-spacing:.07em;color:var(--text-mute)}
.stat .sv{font-size:30px;font-weight:700;letter-spacing:-.02em;margin:8px 0 4px}
.stat .sd{font-size:12.5px;color:var(--ok);font-family:var(--mono)}
.stat .sd.down{color:#f45668}

/* ---- table ---- */
.tbl{width:100%;border-collapse:collapse;font-size:14px}
.tbl th{text-align:left;font-family:var(--mono);font-size:11px;text-transform:uppercase;letter-spacing:.07em;
  color:var(--text-mute);font-weight:500;padding:0 14px 12px}
.tbl td{padding:13px 14px;border-top:1px solid var(--line-soft);color:var(--text-dim)}
.tbl td:first-child{color:var(--text);font-weight:500}
.tbl tbody tr:hover{background:color-mix(in srgb,var(--brand) 6%,transparent)}

/* ---- avatar ---- */
.av{width:42px;height:42px;border-radius:50%;display:grid;place-items:center;font-weight:700;font-size:15px;
  color:var(--on-brand);background:var(--brand);border:2px solid var(--bg)}
.av.sq{border-radius:12px}
.av-group{display:flex}
.av-group .av{margin-left:-12px;box-shadow:0 0 0 0 transparent}
.av-group .av:first-child{margin-left:0}
.av-more{background:var(--surface-3);color:var(--text-dim);font-size:12px}

/* ---- list ---- */
.lst{display:flex;flex-direction:column;gap:2px}
.lst-item{display:flex;align-items:center;gap:13px;padding:12px 13px;border-radius:var(--r);transition:.15s;cursor:pointer}
.lst-item:hover{background:var(--bg-2)}
.lst-item .li-ico{width:36px;height:36px;border-radius:9px;display:grid;place-items:center;flex-shrink:0;
  background:color-mix(in srgb,var(--brand) 13%,transparent);color:var(--brand-300)}
.lst-item .li-ico svg{width:18px;height:18px}
.lst-item .li-t{font-size:14.5px;font-weight:500;color:var(--text)}
.lst-item .li-s{font-size:12.5px;color:var(--text-mute);font-family:var(--mono)}
.lst-item .li-end{margin-left:auto;color:var(--text-mute)}

/* ---- accordion ---- */
.acc{border:1px solid var(--line);border-radius:var(--r);overflow:hidden;background:var(--bg-2)}
.acc-item + .acc-item{border-top:1px solid var(--line-soft)}
.acc-h{width:100%;display:flex;align-items:center;justify-content:space-between;gap:12px;
  padding:16px 18px;background:none;border:none;color:var(--text);font-family:var(--sans);font-weight:600;
  font-size:15px;text-align:left;cursor:pointer}
.acc-h svg{width:18px;height:18px;color:var(--text-mute);transition:transform .2s}
.acc-item.open .acc-h svg{transform:rotate(180deg)}
.acc-b{max-height:0;overflow:hidden;transition:max-height .25s ease}
.acc-b p{margin:0;padding:0 18px 18px;color:var(--text-dim);font-size:14px;line-height:1.55}
.acc-item.open .acc-b{max-height:200px}

/* ---- kbd / inline code ---- */
kbd{font-family:var(--mono);font-size:12px;background:var(--surface-3);border:1px solid var(--line);
  border-bottom-width:2px;border-radius:6px;padding:3px 7px;color:var(--text)}
code.inline{font-family:var(--mono);font-size:.88em;background:color-mix(in srgb,var(--brand) 12%,transparent);
  color:var(--brand-300);padding:2px 6px;border-radius:6px}

/* ---- modal ---- */
.backdrop{position:fixed;inset:0;background:rgba(6,7,10,.7);backdrop-filter:blur(4px);z-index:90;
  display:flex;align-items:center;justify-content:center;padding:24px;opacity:0;transition:.2s}
.backdrop.show{opacity:1}
.modal{width:100%;max-width:440px;background:var(--surface);border:1px solid var(--line);
  border-radius:var(--r-lg);padding:28px;transform:scale(.96);transition:.2s}
.backdrop.show .modal{transform:scale(1)}
.modal h3{margin:0 0 10px;font-size:21px;font-weight:700;letter-spacing:-.02em}
.modal p{margin:0 0 22px;color:var(--text-dim);font-size:15px;line-height:1.55}
.modal .m-actions{display:flex;gap:10px;justify-content:flex-end}

/* ---- button extras ---- */
.btn-danger{background:#f45668;color:#fff}
.btn-danger:hover{background:#ff6677;transform:translateY(-2px)}
.btn-ok{background:var(--ok);color:#04231a}
.btn-ok:hover{filter:brightness(1.08);transform:translateY(-2px)}
.btn-icon{padding:0;width:44px;height:44px}
.btn-group{display:inline-flex;border:1px solid var(--line);border-radius:var(--pill);overflow:hidden;background:var(--bg-2)}
.btn-group button{background:none;border:none;color:var(--text-dim);padding:11px 17px;font-family:var(--sans);
  font-weight:600;font-size:14px;cursor:pointer;transition:.15s;display:inline-flex;align-items:center;gap:7px}
.btn-group button svg{width:16px;height:16px}
.btn-group button + button{border-left:1px solid var(--line)}
.btn-group button:hover{color:var(--text);background:color-mix(in srgb,var(--brand) 10%,transparent)}
.btn-group button.on{background:var(--brand);color:var(--on-brand)}

/* ---- number stepper ---- */
.stepper{display:inline-flex;align-items:center;border:1px solid var(--line);border-radius:var(--r);background:var(--bg-2);overflow:hidden}
.stepper button{width:42px;height:46px;background:none;border:none;color:var(--text-dim);cursor:pointer;display:grid;place-items:center}
.stepper button svg{width:16px;height:16px}
.stepper button:hover{color:var(--text);background:var(--surface-3)}
.stepper input{width:58px;height:46px;border:none;border-inline:1px solid var(--line);background:none;
  color:var(--text);text-align:center;font-family:var(--mono);font-size:15px}
.stepper input:focus{outline:none}

/* ---- spinner ---- */
.spinner{width:32px;height:32px;border-radius:50%;border:3px solid var(--surface-3);border-top-color:var(--brand);animation:spin .7s linear infinite}
.spinner.sm{width:18px;height:18px;border-width:2px}
@keyframes spin{to{transform:rotate(360deg)}}

/* ---- empty state ---- */
.empty{text-align:center;padding:26px 16px;display:flex;flex-direction:column;align-items:center;gap:5px}
.empty .e-ic{width:54px;height:54px;border-radius:14px;display:grid;place-items:center;
  background:color-mix(in srgb,var(--brand) 12%,transparent);color:var(--brand-300);margin-bottom:8px}
.empty .e-ic svg{width:26px;height:26px}
.empty h4{margin:0;font-size:16px;font-weight:600}
.empty p{margin:0;color:var(--text-mute);font-size:13.5px}

/* ---- banner ---- */
.banner{display:flex;align-items:center;gap:13px;padding:14px 18px;border-radius:var(--r);background:var(--brand);color:var(--on-brand);font-size:14.5px}
.banner svg{width:20px;height:20px;flex-shrink:0}
.banner a{color:var(--on-brand);text-decoration:underline;font-weight:600}
.banner .bx{margin-left:auto;background:rgba(0,0,0,.14);border:none;color:var(--on-brand);width:30px;height:30px;border-radius:8px;display:grid;place-items:center;cursor:pointer;flex-shrink:0}
.banner .bx:hover{background:rgba(0,0,0,.26)}
.banner .bx svg{width:15px;height:15px}

/* ---- steps ---- */
.steps{display:flex;align-items:center;flex-wrap:wrap;gap:0}
.steps .st{display:flex;align-items:center;gap:10px}
.steps .sc{width:30px;height:30px;border-radius:50%;display:grid;place-items:center;font-family:var(--mono);font-size:13px;
  border:1px solid var(--line);background:var(--bg-2);color:var(--text-mute);flex-shrink:0}
.steps .sc svg{width:15px;height:15px}
.steps .st.done .sc{background:var(--brand);border-color:var(--brand);color:var(--on-brand)}
.steps .st.active .sc{border-color:var(--brand);color:var(--brand-300)}
.steps .sl{font-size:13.5px;color:var(--text-mute)}
.steps .st.done .sl,.steps .st.active .sl{color:var(--text)}
.steps .sline{width:30px;height:1.5px;background:var(--line);margin:0 12px;flex-shrink:0}
.steps .st.done + .sline{background:var(--brand)}

/* ---- divider ---- */
.divider{display:flex;align-items:center;gap:14px;color:var(--text-mute);font-family:var(--mono);font-size:12px}
.divider::before,.divider::after{content:"";flex:1;height:1px;background:var(--line-soft)}

/* ---- dropdown menu ---- */
.menu{background:var(--surface);border:1px solid var(--line);border-radius:var(--r);padding:6px;box-shadow:var(--shadow)}
.menu-item{display:flex;align-items:center;gap:11px;padding:10px 12px;border-radius:var(--r-sm);color:var(--text-dim);font-size:14px;cursor:pointer;transition:.15s}
.menu-item:hover{background:color-mix(in srgb,var(--brand) 12%,transparent);color:var(--text)}
.menu-item svg{width:16px;height:16px}
.menu-item.danger{color:#f45668}.menu-item.danger:hover{background:rgba(244,86,104,.12)}
.menu-sep{height:1px;background:var(--line-soft);margin:6px 4px}

/* ---- file row ---- */
.filerow{display:flex;align-items:center;gap:13px;padding:13px 15px;background:var(--bg-2);border:1px solid var(--line);border-radius:var(--r)}
.filerow .fi{width:38px;height:38px;border-radius:9px;display:grid;place-items:center;background:color-mix(in srgb,var(--brand) 13%,transparent);color:var(--brand-300);flex-shrink:0}
.filerow .fi svg{width:18px;height:18px}
.filerow .fmeta{flex:1;min-width:0}
.filerow .fn{font-size:14px;font-weight:500;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.filerow .fp{margin-top:7px}
.filerow .fx{background:none;border:none;color:var(--text-mute);padding:6px;border-radius:8px;cursor:pointer;flex-shrink:0}
.filerow .fx:hover{color:#f45668}
.filerow .fx svg{width:16px;height:16px}
