/* BOXPLA — extracted from browser.html (v1).
   Block 1: self-hosted DM Sans / DM Mono / Saira Condensed @font-face declarations.
   Block 2: main stylesheet (theme tokens, layout, components, responsive rules). */

/* ── @font-face block ── */
/* Self-hosted fonts — see /fonts/*.woff2 on assets.boxpla.app.
   DM Sans is a variable font: one file serves weights 300/400/500/600. */
@font-face{font-family:'DM Sans';font-style:normal;font-weight:300 600;font-display:swap;
  src:url(https://assets.boxpla.app/fonts/dm-sans-latin.woff2?v=1) 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 Sans';font-style:normal;font-weight:300 600;font-display:swap;
  src:url(https://assets.boxpla.app/fonts/dm-sans-latin-ext.woff2?v=1) 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(https://assets.boxpla.app/fonts/dm-mono-400-latin.woff2?v=1) 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(https://assets.boxpla.app/fonts/dm-mono-400-latin-ext.woff2?v=1) 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(https://assets.boxpla.app/fonts/dm-mono-500-latin.woff2?v=1) 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(https://assets.boxpla.app/fonts/dm-mono-500-latin-ext.woff2?v=1) 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:'Saira Condensed';font-style:normal;font-weight:600;font-display:swap;
  src:url(https://assets.boxpla.app/fonts/saira-condensed-600-latin.woff2?v=1) 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:'Saira Condensed';font-style:normal;font-weight:600;font-display:swap;
  src:url(https://assets.boxpla.app/fonts/saira-condensed-600-latin-ext.woff2?v=1) 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;}

/* ── main stylesheet ── */
html[data-theme="dark"]{
  --bg:#0d0f14;--bg2:#13161d;--bg3:#1a1e28;
  --border:rgba(255,255,255,0.07);--border2:rgba(255,255,255,0.12);
  --text:#e8eaf0;--text2:#a2a9ba;--text3:#8f96a8;
  --accent:#c9a96e;--accent2:#e8c98a;
  --accent-text:#c9a96e;--warn-text:#facc15;--danger-text:#f87171;--pink-text:#f472b6;--blue-text:#60a5fa;--purple-text:#c4b5fd;--bronze-text:#d97706;--tier-neutral-text:#8f96a8;
  --accent-glow:rgba(201,169,110,0.06);
  --hex-line:#c9a96e;--hex-fill:rgba(201,169,110,0.08);--hex-ring:rgba(201,169,110,0.6);
  --row-hover:rgba(255,255,255,0.025);
  --thead-bg:rgba(255,255,255,0.02);
  --toggle-track:#2a2f3d;--toggle-thumb:#c9a96e;
  --scrollbar-thumb:rgba(255,255,255,0.12);
  --dropdown-shadow:0 8px 32px rgba(0,0,0,0.5);
  --modal-overlay:rgba(0,0,0,0.72);
  --input-bg:#0d0f14;
  --error-bg:rgba(239,68,68,0.08);--error-border:rgba(239,68,68,0.25);--error-text:#f87171;
  --success-bg:rgba(34,197,94,0.08);--success-border:rgba(34,197,94,0.25);--success-text:#4ade80;
  --danger-bg:rgba(239,68,68,0.08);--danger-border:rgba(239,68,68,0.2);
}
html[data-theme="light"]{
  --bg:#f4f2ee;--bg2:#ffffff;--bg3:#f0ede8;
  --border:rgba(0,0,0,0.08);--border2:rgba(0,0,0,0.13);
  --text:#1a1a22;--text2:#343948;--text3:#555b6d;
  --accent:#9a6f35;--accent2:#b8893d;
  --accent-text:#76521f;--warn-text:#7c4a00;--danger-text:#b91c1c;--pink-text:#be185d;--blue-text:#1d4ed8;--purple-text:#6d28d9;--bronze-text:#7c4a00;--tier-neutral-text:#555b6d;
  --accent-glow:rgba(154,111,53,0.05);
  --hex-line:#9a6f35;--hex-fill:rgba(154,111,53,0.08);--hex-ring:rgba(154,111,53,0.22);
  --row-hover:rgba(0,0,0,0.025);
  --thead-bg:rgba(0,0,0,0.02);
  --toggle-track:#e0dbd2;--toggle-thumb:#9a6f35;
  --scrollbar-thumb:rgba(0,0,0,0.15);
  --dropdown-shadow:0 8px 32px rgba(0,0,0,0.15);
  --modal-overlay:rgba(0,0,0,0.55);
  --input-bg:#ffffff;
  --error-bg:rgba(239,68,68,0.06);--error-border:rgba(239,68,68,0.2);--error-text:#b91c1c;
  --success-bg:rgba(34,197,94,0.06);--success-border:rgba(34,197,94,0.2);--success-text:#166534;
  --danger-bg:rgba(239,68,68,0.06);--danger-border:rgba(239,68,68,0.15);
}

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;}
html{transition:background 0.3s,color 0.3s;}
body{background:var(--bg);color:var(--text);font-family:'DM Sans',sans-serif;font-size:13px;min-height:100vh;overflow-x:hidden;transition:background 0.3s,color 0.3s;}
button,input,select,textarea,optgroup,option{font-family:'DM Sans',sans-serif;}
body::after{content:'';position:fixed;top:-200px;left:50%;transform:translateX(-50%);width:800px;height:400px;background:radial-gradient(ellipse,var(--accent-glow) 0%,transparent 70%);pointer-events:none;z-index:0;transition:background 0.3s;}
.container{max-width:1250px;margin:0 auto;padding:0 24px 0;position:relative;z-index:1;display:flex;flex-direction:column;min-height:100vh;}

/* ── HEADER ── */
header{padding:24px 0 28px;border-bottom:1px solid var(--border);margin-bottom:24px;transition:border-color 0.3s;}
.header-inner{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;flex-wrap:nowrap;}
.logo-link,.logo-link:any-link{display:block;text-decoration:none;color:inherit;}
.logo-area .brand-logo{display:flex;align-items:center;line-height:1;margin-bottom:5px;}
.logo-area .g{font-family:'Saira Condensed',sans-serif;font-weight:600;font-size:48px;letter-spacing:0.04em;text-transform:uppercase;line-height:1;background:linear-gradient(135deg,var(--accent2),var(--accent));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;}
.logo-area .brand-logo .hex-lg{width:58px;height:58px;margin-left:-13px;margin-right:-10px;}
.logo-area .brand-logo .hex-sm{width:32px;height:32px;margin-left:-7px;margin-right:-5px;display:none;}
.logo-area .subtitle{font-size:9px;font-weight:300;color:var(--accent-text);letter-spacing:0.32em;text-transform:uppercase;transition:color 0.3s;margin:0;}
.header-right{display:flex;flex-direction:column;align-items:flex-end;gap:12px;}

/* ── THEME TOGGLE ── */
.theme-toggle{display:flex;align-items:center;gap:8px;cursor:pointer;font-size:11px;color:var(--text3);user-select:none;transition:color 0.3s;}
.theme-toggle:hover{color:var(--text2);}
.toggle-label{font-size:11px;font-weight:500;text-transform:uppercase;letter-spacing:0.1em;}
.toggle-track{position:relative;width:44px;height:24px;background:var(--toggle-track);border-radius:12px;border:1px solid var(--border2);transition:background 0.3s,border-color 0.3s;flex-shrink:0;}
.toggle-thumb{position:absolute;top:3px;left:3px;width:16px;height:16px;border-radius:50%;background:var(--toggle-thumb);transition:transform 0.25s cubic-bezier(.4,0,.2,1),background 0.3s;display:flex;align-items:center;justify-content:center;font-size:9px;line-height:1;}
html[data-theme="light"] .toggle-thumb{transform:translateX(20px);}

/* Match admin.html toggle design on desktop */
@media(min-width:780px){
  .theme-toggle{
    gap:7px;
    background:var(--bg2);
    border:1px solid var(--border2);
    padding:5px 10px;
    border-radius:20px;
    transition:color 0.3s,background 0.3s;
  }
  .toggle-track{
    width:30px;
    height:16px;
    background:var(--toggle-track,#2a2f3d);
    border-radius:8px;
    transition:background 0.3s;
  }
  .toggle-thumb{
    top:2px;
    left:2px;
    width:10px;
    height:10px;
    background:var(--accent);
    transition:transform 0.25s cubic-bezier(.4,0,.2,1);
  }
  html[data-theme="light"] .toggle-thumb{transform:translateX(14px);}
  .toggle-label{
    font-size:11px;
    font-weight:400;
    text-transform:none;
    letter-spacing:0;
  }
}

/* ── USER MENU ── */
.user-menu-wrap{position:relative;display:inline-block;}
.user-btn{
  display:flex;align-items:center;gap:8px;cursor:pointer;
  background:var(--bg2);border:1px solid var(--border2);
  border-radius:20px;padding:5px 12px 5px 6px;
  transition:border-color 0.2s,background 0.2s;
  user-select:none;
}
.user-btn:hover{border-color:var(--accent-text);}
.user-avatar{
  width:26px;height:26px;border-radius:50%;
  background:linear-gradient(135deg,var(--accent2),var(--accent));
  background-color:var(--accent);
  display:flex;align-items:center;justify-content:center;
  font-size:11px;font-weight:700;color:#000;flex-shrink:0;
  overflow:hidden;
}
.user-avatar img{width:100%;height:100%;object-fit:cover;}
html[data-theme="light"] .user-avatar{background:var(--accent-text);color:#fff;}
.user-name{font-size:12px;font-weight:500;color:var(--text);white-space:nowrap;}
.user-chevron{color:var(--text3);transition:transform 0.2s;font-size:10px;}
.user-menu-wrap.open .user-chevron{transform:rotate(180deg);}

.user-dropdown{
  display:none;position:fixed;
  background:var(--bg2);border:1px solid var(--border2);
  border-radius:12px;box-shadow:var(--dropdown-shadow);
  min-width:200px;z-index:9999;overflow:hidden;
  padding:6px 0;
}
.user-dropdown.open{display:block;}

.user-dropdown-header{
  padding:10px 14px 8px;border-bottom:1px solid var(--border);
  margin-bottom:4px;
}
.user-dropdown-name{font-size:13px;font-weight:600;color:var(--text);}
.user-dropdown-email{font-size:11px;color:var(--text3);margin-top:2px;}

.menu-item{
  display:flex;align-items:center;gap:10px;
  padding:9px 14px;font-size:13px;color:var(--text2);
  cursor:pointer;transition:background 0.12s,color 0.12s;
  text-decoration:none;border:none;background:none;width:100%;text-align:left;
}
.menu-item:hover{background:var(--row-hover);color:var(--text);}
.menu-item svg{flex-shrink:0;opacity:0.6;}
.menu-item:hover svg{opacity:1;}
@media (hover:none),(pointer:coarse){
  .menu-item svg{opacity:1;}
  .menu-item:not(.danger) svg{color:var(--text);}
}
.menu-count{font-size:10px;font-weight:700;color:var(--accent-text);background:rgba(201,169,110,0.12);border:1px solid rgba(201,169,110,0.25);padding:1px 6px;border-radius:8px;margin-left:auto;min-width:18px;text-align:center;}
.menu-count--green{color:var(--success-text);background:rgba(34,197,94,0.12);border-color:rgba(34,197,94,0.25);}
.menu-count--pink{color:var(--pink-text);background:rgba(236,72,153,0.12);border-color:rgba(236,72,153,0.25);}
.menu-count--blue{color:var(--blue-text);background:rgba(59,130,246,0.12);border-color:rgba(59,130,246,0.25);}
.menu-divider{height:1px;background:var(--border);margin:4px 0;}
.menu-item.danger{color:var(--danger-text);}
.menu-item.danger:hover{background:rgba(239,68,68,0.08);color:var(--danger-text);}

/* Not logged in state */
.login-btn{
  display:inline-flex;align-items:center;gap:6px;
  padding:7px 14px;border-radius:8px;font-size:12px;font-weight:600;
  background:linear-gradient(135deg,var(--accent2),var(--accent));
  background-color:var(--accent);
  color:#000;text-decoration:none;border:none;cursor:pointer;
  transition:opacity 0.15s;letter-spacing:0.04em;
}
.login-btn:hover{opacity:0.9;}
html[data-theme="light"] .login-btn{background:var(--accent-text);background-color:var(--accent-text);color:#fff;}

/* ── CONTROLS ── */
.controls{display:flex;gap:8px;align-items:center;margin-bottom:16px;flex-wrap:wrap;}
.search-wrap{position:relative;flex:1;min-width:160px;max-width:300px;}
.search-wrap svg{position:absolute;left:10px;top:50%;transform:translateY(-50%);opacity:0.35;pointer-events:none;stroke:var(--text);transition:stroke 0.3s;}
input[type="text"]{width:100%;padding:9px 12px 9px 32px;background:var(--bg2);border:1px solid var(--border2);border-radius:8px;color:var(--text);font-family:'DM Sans',sans-serif;font-size:14px;outline:none;transition:border-color 0.2s,box-shadow 0.2s,background 0.3s,color 0.3s;}
input[type="text"]:focus{border-color:rgba(201,169,110,0.4);box-shadow:0 0 0 3px rgba(201,169,110,0.08);}
input[type="text"]::placeholder{color:var(--text3);}
select{padding:9px 28px 9px 10px;background:var(--bg2);border:1px solid var(--border2);border-radius:8px;color:var(--text);font-family:'DM Sans',sans-serif;font-size:13px;outline:none;appearance:none;cursor:pointer;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6'%3E%3Cpath d='M0 0l5 6 5-6z' fill='%239098aa'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 9px center;transition:border-color 0.2s,background-color 0.3s,color 0.3s;}
select:focus{border-color:rgba(201,169,110,0.4);}
select option{background:var(--bg2);color:var(--text);}
.bp-select{position:relative;display:inline-block;min-width:140px;}
.bp-select-source{position:absolute!important;width:1px!important;height:1px!important;opacity:0!important;pointer-events:none!important;}
.bp-select-button{width:100%;min-height:38px;display:flex;align-items:center;justify-content:space-between;gap:10px;padding:9px 11px;border-radius:8px;border:1px solid var(--border2);background:var(--bg2);color:var(--text);font-family:'DM Sans',sans-serif;font-size:13px;text-align:left;cursor:pointer;transition:border-color .2s,box-shadow .2s,background .3s,color .2s;}
.bp-select-button:hover{border-color:rgba(201,169,110,.35);}
.bp-select-button:focus{outline:none;border-color:rgba(201,169,110,.5);box-shadow:0 0 0 3px rgba(201,169,110,.07);}
.bp-select-button svg{flex-shrink:0;color:var(--text3);transition:color .15s,transform .15s;}
.bp-select.open .bp-select-button{border-color:rgba(201,169,110,.55);box-shadow:0 0 0 3px rgba(201,169,110,.07);}
.bp-select.open .bp-select-button svg{color:var(--accent-text);transform:rotate(180deg);}
.bp-select-menu{display:none;position:absolute;left:0;right:0;top:calc(100% + 6px);z-index:35;max-height:320px;overflow:auto;background:var(--bg2);border:1px solid var(--border2);border-radius:10px;box-shadow:var(--dropdown-shadow);}
.bp-select.open .bp-select-menu{display:block;animation:rowIn .14s ease both;}
.bp-select-option{display:flex;align-items:center;width:100%;padding:10px 12px;border:none;border-bottom:1px solid var(--border);background:transparent;color:var(--text2);font-family:'DM Sans',sans-serif;font-size:13px;text-align:left;cursor:pointer;transition:background .12s,color .12s;}
.bp-select-option:last-child{border-bottom:none;}
.bp-select-option:hover,.bp-select-option[aria-selected="true"]{background:var(--row-hover);color:var(--accent-text);}
.bp-select-option:disabled{opacity:.45;cursor:not-allowed;}
.bp-select-group{padding:8px 12px 5px;border-bottom:1px solid var(--border);color:var(--text3);font-size:9px;font-weight:700;text-transform:uppercase;letter-spacing:.1em;}
.count-badge{margin-left:auto;font-size:13px;color:var(--text3);white-space:nowrap;padding:5px 12px;background:var(--bg3);border-radius:20px;border:1px solid var(--border);transition:background 0.3s,color 0.3s,border-color 0.3s;}
.page-title-compact{font-family:'Saira Condensed',sans-serif;font-size:22px;font-weight:600;color:var(--text);letter-spacing:0.06em;margin:0 0 14px;line-height:1.15;}
html[data-theme="light"] .page-title-compact,
html[data-theme="light"] .page-heading,
html[data-theme="light"] .settings-page-title{color:var(--accent-text);}

/* ── VIEW SELECTOR (table density: medium | large) ── */
.view-selector{display:flex;gap:3px;background:var(--bg2);border:1px solid var(--border2);border-radius:8px;padding:3px;}
.view-btn{display:flex;align-items:center;justify-content:center;width:32px;height:28px;border-radius:6px;cursor:pointer;color:var(--text3);border:none;background:transparent;transition:background 0.15s,color 0.15s;}
.view-btn:hover{color:var(--text2);}
.view-btn.active{background:var(--bg3);color:var(--accent-text);}

/* ── DESKTOP TABLE ──
   Fused-row design. Medium (default) and Large densities share the same
   markup — body.view-large only swaps the image-size / row-padding vars. */
:root{--img-ph:96px;--img-pw:108px;--img-lw:104px;--img-lh:96px;--row-pad:7px;}
body.view-large{--img-ph:160px;--img-pw:148px;--img-lw:155px;--img-lh:148px;--row-pad:20px;}
.table-wrap{overflow-x:auto;overflow-y:hidden;border-radius:12px;border:1px solid var(--border);background:var(--bg2);transition:background 0.3s,border-color 0.3s;container-type:inline-size;}
table{width:100%;border-collapse:collapse;font-size:13px;}
thead{border-bottom:1px solid var(--border2);background:var(--thead-bg);transition:background 0.3s,border-color 0.3s;}
thead th{padding:10px 14px;text-align:left;font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:0.11em;color:var(--text3);white-space:nowrap;user-select:none;transition:color 0.15s;}
thead th[data-act]{cursor:pointer;}
thead th[data-act]:hover{color:var(--accent-text);}
thead th.sorted{color:var(--accent-text);}
thead th.num{text-align:right;}
thead th .arrow{margin-left:3px;font-size:9px;color:inherit;}
thead th.sorted .arrow{color:inherit;}
tbody tr{border-bottom:1px solid var(--border);transition:background 0.12s;}
tbody tr:last-child{border-bottom:none;}
tbody tr:hover{background:var(--row-hover);}
tbody td{padding:var(--row-pad) 14px;vertical-align:middle;}
.thumb-cell{width:calc(var(--img-pw) + 20px);}
.thumb-portrait{height:var(--img-ph);width:auto;max-width:var(--img-pw);border-radius:8px;object-fit:contain;display:block;border:1px solid var(--border2);background:var(--bg3);margin:0 auto;}
.thumb-landscape{width:var(--img-lw);height:auto;max-height:var(--img-lh);border-radius:8px;object-fit:contain;display:block;border:1px solid var(--border2);background:var(--bg3);margin:0 auto;}
.r-noimg{width:var(--img-pw);height:var(--img-ph);border-radius:8px;border:1px dashed var(--border2);background:var(--bg3);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:5px;color:var(--text3);margin:0 auto;}
.r-noimg span{font-size:8px;letter-spacing:0.08em;text-transform:uppercase;opacity:0.7;}
/* name cell */
.r-name-col{min-width:230px;}
.r-name{font-weight:600;color:var(--text);font-size:15px;line-height:1.25;}
.r-jp{font-size:12px;color:var(--text2);margin-top:2px;}
.r-kitno{font-family:'DM Mono',monospace;font-size:11.5px;color:var(--accent-text);margin-top:5px;}
.r-chiprow{display:flex;align-items:center;gap:9px;margin-top:8px;flex-wrap:wrap;}
/* chips */
.grade{display:inline-flex;align-items:center;font-family:'DM Mono',monospace;font-size:10.5px;font-weight:600;letter-spacing:0.04em;padding:2px 8px;border-radius:5px;color:#13161d;background:#cdd3df;}
.grade-MG{background:#e8c98a;}.grade-RG{background:#f0a3a3;}.grade-HG{background:#8fd4e6;}
.grade-PG{background:#c9a3f0;}.grade-SD{background:#8fd6a8;}.grade-EG{background:#9ad9e8;}
.grade-Angel{background:#9ec3f5;}.grade-Demon{background:#f5b98f;}.grade-Beast{background:#8fd6a8;}
.grade-Lamia{background:#f0a3c8;}.grade-Garuda{background:#c3a3f0;}.grade-Dragon{background:#f0a3a3;}
.grade-Accessory{background:#cdbaf2;}
.avail{display:inline-flex;align-items:center;gap:6px;font-size:12px;color:var(--text2);}
.avail-dot{width:7px;height:7px;border-radius:50%;flex-shrink:0;}
.avail-available .avail-dot{background:#22c55e;box-shadow:0 0 0 3px rgba(34,197,94,0.12);}
.avail-pre_order .avail-dot{background:#eab308;box-shadow:0 0 0 3px rgba(234,179,8,0.12);}
.avail-out_of_print .avail-dot{background:#ef4444;box-shadow:0 0 0 3px rgba(239,68,68,0.12);}
.avail-out_of_print{color:var(--text3);}
.avail-announced .avail-dot{background:#8b5cf6;box-shadow:0 0 0 3px rgba(139,92,246,0.12);}
.r-score{display:inline-flex;align-items:center;gap:3px;font-family:'DM Mono',monospace;font-size:11px;font-weight:500;color:var(--accent-text);}
.r-sc{font-size:10px;color:var(--text3);font-weight:400;margin-left:1px;}
/* specs */
.r-specs{font-size:12.5px;color:var(--text2);line-height:1.5;}
.r-specs .sp-strong{color:var(--text);}
.r-series{font-size:12px;color:var(--text3);margin-top:2px;max-width:200px;}
.r-info-col{display:none;}
.r-info{min-width:170px;display:flex;flex-direction:column;gap:2px;}
.r-info-primary{font-size:12.5px;color:var(--text2);line-height:1.45;}
.r-info-primary .sp-strong{color:var(--text);}
.r-info-secondary{font-size:12px;color:var(--text3);line-height:1.35;}
.r-info-tertiary{display:flex;align-items:center;gap:10px;flex-wrap:wrap;font-family:'DM Mono',monospace;font-size:11.5px;color:var(--text3);margin-top:2px;}
.r-info-price{color:var(--accent-text);}
.r-info-dims{display:none;align-items:center;gap:10px;flex-wrap:wrap;font-family:'DM Mono',monospace;font-size:11.5px;color:var(--text3);margin-top:2px;}
.r-release{font-family:'DM Mono',monospace;font-size:12.5px;color:var(--text2);white-space:nowrap;}
/* numerics */
td.num{text-align:right;font-family:'DM Mono',monospace;font-variant-numeric:tabular-nums;white-space:nowrap;}
.num-strong{font-size:13px;font-weight:500;color:var(--text);}
.num-soft{font-size:12.5px;color:var(--text2);}
.num-sub{font-size:12.5px;color:var(--text3);margin-top:3px;}
.num-weight,.r-info-weight,.spec-weight,.chip-value.chip-weight{color:var(--accent-text);}
/* row actions */
.r-actions{display:flex;flex-direction:column;gap:7px;align-items:stretch;width:124px;}
.r-collect{display:inline-flex;align-items:center;justify-content:center;gap:6px;height:32px;padding:0 16px 0 10px;border-radius:7px;font-size:12px;font-weight:500;border:1px solid var(--border2);background:var(--bg3);color:var(--text3);cursor:pointer;white-space:nowrap;transition:color .15s,border-color .15s,background .15s;font-family:'DM Sans',sans-serif;position:relative;overflow:hidden;}
.r-collect:hover{color:var(--accent-text);border-color:rgba(201,169,110,0.4);background:rgba(201,169,110,0.1);}
.r-collect.is-owned,.r-collect.is-building,.r-collect.is-wishlist,.r-collect.is-built{color:var(--accent-text);border-color:var(--accent-text);background:transparent;font-weight:600;}
.r-collect.is-owned{--collect-marker:#16a34a;}
.r-collect.is-building{--collect-marker:#ca8a04;}
.r-collect.is-wishlist{--collect-marker:#ec4899;}
.r-collect.is-built{--collect-marker:#3b82f6;}
.r-collect.is-owned::after,.r-collect.is-building::after,.r-collect.is-wishlist::after,.r-collect.is-built::after{content:"";position:absolute;right:5px;top:7px;bottom:7px;width:3px;border-radius:999px;background:var(--collect-marker,var(--accent));}
.r-addbox{display:inline-flex;align-items:center;justify-content:center;gap:6px;height:32px;border-radius:7px;font-size:12px;font-weight:500;border:1px solid var(--border2);background:var(--bg3);color:var(--text3);cursor:pointer;transition:color .15s,border-color .15s;font-family:'DM Sans',sans-serif;position:relative;}
.r-addbox:hover,.r-addbox.added{color:var(--accent-text);border-color:rgba(201,169,110,0.4);background:rgba(201,169,110,0.1);}
.r-feedback{display:inline-flex;align-items:center;justify-content:center;gap:5px;height:32px;border-radius:7px;font-size:11.5px;font-weight:600;border:1px solid var(--accent);background:transparent;color:var(--accent-text);cursor:pointer;transition:background .15s;font-family:'DM Sans',sans-serif;}
.r-feedback:hover{background:rgba(201,169,110,0.1);}
html[data-theme="light"] .r-feedback:hover{background:rgba(154,111,53,0.08);}

@container (max-width:1066px){
  .r-info-col{display:table-cell;}
  .r-meta-col,
  .r-release-col,
  .r-price-col{display:none;}
}
@container (max-width:890px){
  .r-box-col{display:none;}
  .r-info-dims{display:flex;}
}

/* ── COLLECT MODAL (mobile) ── */
.collect-modal-overlay{
  display:none;position:fixed;inset:0;
  background:rgba(0,0,0,0.5);z-index:10000;
  backdrop-filter:blur(2px);
}
.collect-modal-overlay.open{display:flex;align-items:flex-end;}
.collect-modal-sheet{
  width:100%;background:var(--bg2);
  border-radius:16px 16px 0 0;
  border-top:1px solid var(--border2);
  padding:8px 0 calc(env(safe-area-inset-bottom) + 16px);
  
}

.collect-modal-handle{
  width:36px;height:4px;border-radius:2px;
  background:var(--border2);margin:0 auto 12px;
}
.collect-modal-title{
  font-size:11px;font-weight:600;text-transform:uppercase;
  letter-spacing:0.12em;color:var(--text3);
  padding:0 16px 8px;
}
.collect-modal-option{
  display:flex;align-items:center;gap:12px;
  padding:13px 20px;font-size:15px;font-weight:500;
  color:var(--text2);cursor:pointer;
  font-family:'DM Sans',sans-serif;
  border:none;background:none;width:100%;text-align:left;
  transition:background 0.1s;
}
.collect-modal-option:hover{background:var(--row-hover);}
.collect-modal-option.active{color:var(--accent-text);font-weight:600;}
.collect-modal-option .co-icon{width:32px;height:32px;border-radius:50%;display:flex;align-items:center;justify-content:center;flex-shrink:0;}
.collect-modal-option.remove{color:var(--text3);border-top:1px solid var(--border);margin-top:4px;}
.collect-modal-option.remove:hover{color:var(--danger-text);}

.collect-dropdown{
  display:none;position:fixed;
  background:var(--bg2);border:1px solid var(--border2);
  border-radius:10px;box-shadow:var(--dropdown-shadow);
  min-width:160px;z-index:9999;overflow:hidden;
  padding:4px 0;
}
.collect-dropdown.open{display:block;}
.collect-option{
  display:flex;align-items:center;gap:9px;
  padding:9px 13px;font-size:13px;color:var(--text2);
  cursor:pointer;transition:background 0.12s;
  font-family:'DM Sans',sans-serif;
  border:none;background:none;width:100%;text-align:left;
}
.collect-option:hover{background:var(--row-hover);color:var(--text);}
.collect-option.active{color:var(--accent-text);font-weight:600;}
.collect-option.remove{color:var(--text3);border-top:1px solid var(--border);margin-top:4px;padding-top:9px;}
.collect-option.remove:hover{color:var(--danger-text);}

.atb-kit-badge{position:absolute;top:-7px;right:-7px;background:var(--accent);color:#000;font-size:9px;font-weight:700;min-width:15px;height:15px;border-radius:8px;display:flex;align-items:center;justify-content:center;padding:0 3px;pointer-events:none;line-height:1;}
html[data-theme="light"] .atb-kit-badge{background:var(--accent-text);color:#fff;}
.empty{text-align:center;padding:60px 20px;color:var(--text3);}
.empty h3{font-size:16px;margin-bottom:8px;font-family:'Saira Condensed',sans-serif;color:var(--text2);}
/* Breathing room between the content and the bottom-pinned footer */
.table-wrap,.card-list{margin-bottom:28px;}
footer{border-top:1px solid var(--border);display:block;transition:border-color 0.3s;position:relative;z-index:1;margin-top:auto;padding:0;}
.footer-inner{padding:22px 36px 18px;display:flex;flex-direction:column;align-items:stretch;gap:0;}
.footer-brand{display:flex;align-items:center;}
.footer-brand .g{font-family:'Saira Condensed',sans-serif;font-weight:600;letter-spacing:0.04em;text-transform:uppercase;line-height:1;background:linear-gradient(135deg,var(--accent2),var(--accent));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;}
.footer-collab-sep{font-family:'DM Mono',monospace;font-size:11px;color:var(--text);margin:0 8px;flex-shrink:0;}
.footer-sub{display:flex;align-items:flex-end;width:100%;margin-top:-8px;}
.footer-tagline{font-size:11px;color:var(--text3);letter-spacing:0.12em;text-transform:uppercase;margin:0;}
.footer-legal{display:grid;grid-template-columns:auto auto auto auto auto;align-items:center;justify-items:end;column-gap:14px;row-gap:4px;white-space:nowrap;margin-left:auto;}
.footer-legal-link{font-size:11px;color:var(--text3);text-decoration:none;transition:color 0.2s;}
.footer-legal-link:hover{color:var(--accent-text);}
.footer-cost-link{grid-column:1/-1;justify-self:end;}
.footer-cost-label-mobile,.footer-cost-mobile-sep{display:none;}
.footer-sep{color:var(--text3);font-size:10px;}
.footer-copy{font-size:11px;color:var(--text3);}
.footer-link{display:inline-flex;align-items:center;color:inherit;text-decoration:none;transition:opacity 0.2s;-webkit-tap-highlight-color:transparent;}
.footer-link:visited,.footer-link:active,.footer-link:focus{color:inherit;text-decoration:none;}
.footer-link:hover{opacity:0.82;text-decoration:none;}
.legend{display:flex;gap:6px;flex-wrap:wrap;align-items:center;}
.loading-overlay{
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  padding:60px 20px;gap:16px;color:var(--text3);
}
.loading-spinner{
  width:36px;height:36px;border-radius:50%;
  border:3px solid var(--border2);
  border-top-color:var(--accent-text);
  animation:spin 0.8s linear infinite;
}
.loading-msg{font-size:13px;letter-spacing:0.04em;}
.error-msg{
  display:flex;align-items:center;gap:10px;padding:14px 18px;
  background:rgba(239,68,68,0.08);border:1px solid rgba(239,68,68,0.2);
  border-radius:8px;color:var(--error-text);font-size:13px;margin-bottom:16px;
}
@keyframes spin{to{transform:rotate(360deg)}}
/* ── PAGINATION CONTROLS (#pager) ──
   Result-count line + Prev / page numbers / Next. Only one page (≤50 rows) is
   ever in the DOM, so this strip sits directly below the list. */
.pager{
  display:flex;flex-direction:column;align-items:center;gap:12px;
  padding:22px 16px 8px;min-height:44px;
}
.pager:empty{min-height:0;padding:0;}
.pg-info{
  color:var(--text3);font-size:12px;letter-spacing:0.04em;text-align:center;
}
.pg-controls{display:flex;flex-wrap:wrap;align-items:center;justify-content:center;gap:6px;}
.pg-btn{
  min-width:36px;height:36px;padding:0 10px;border-radius:8px;cursor:pointer;
  font-family:'DM Sans',sans-serif;font-size:13px;font-weight:600;
  color:var(--text2);background:var(--card);border:1px solid var(--border2);
  transition:background .12s,border-color .12s,color .12s;
}
.pg-btn:hover:not(:disabled):not(.pg-current){
  background:var(--card-hover,var(--bg2));border-color:var(--accent-text);color:var(--text);
}
.pg-btn.pg-current{
  background:var(--accent);border-color:var(--accent-text);color:#000;cursor:default;
}
html[data-theme="light"] .pg-btn.pg-current{background:var(--accent-text);border-color:var(--accent-text);color:#fff;}
.pg-btn:disabled{opacity:.4;cursor:not-allowed;}
.pg-ellipsis{
  min-width:24px;text-align:center;color:var(--text3);font-size:13px;user-select:none;
}
.pg-loading{display:flex;align-items:center;justify-content:center;min-height:36px;}
.pg-spin{
  display:inline-block;width:24px;height:24px;border-radius:50%;
  border:3px solid var(--border2);border-top-color:var(--accent-text);
  animation:spin 0.8s linear infinite;
}
::-webkit-scrollbar{width:6px;height:6px;}
::-webkit-scrollbar-track{background:var(--bg);}
::-webkit-scrollbar-thumb{background:var(--scrollbar-thumb);border-radius:3px;}
html{scrollbar-color:var(--scrollbar-thumb) var(--bg);scrollbar-width:thin;scrollbar-gutter:stable;}
@keyframes rowIn{from{opacity:0;transform:translateY(4px)}to{opacity:1;transform:translateY(0)}}
/* One soft fade for the whole result container per render (re-triggered from
   JS in _rebuildActiveView), instead of 50 identical per-row animations. */
.view-reveal{animation:rowIn 0.25s ease both;}
@keyframes themeSurfaceOut{from{opacity:1}to{opacity:0}}
@keyframes themeSurfaceIn{from{opacity:0}to{opacity:1}}
@media(min-width:780px){
  html.theme-switching .table-wrap{view-transition-name:browser-results;}
}
@media(max-width:779px){
  html.theme-switching .card-list{view-transition-name:browser-results;}
}
html.theme-switching .table-wrap,
html.theme-switching .table-wrap *,
html.theme-switching .card-list,
html.theme-switching .card-list *{
  transition:none!important;
}
::view-transition-old(browser-results),
::view-transition-new(browser-results){
  animation-duration:0.24s;
  animation-timing-function:cubic-bezier(.4,0,.2,1);
  mix-blend-mode:normal;
}
::view-transition-old(browser-results){animation-name:themeSurfaceOut;}
::view-transition-new(browser-results){animation-name:themeSurfaceIn;}
@media (prefers-reduced-motion: reduce){
  .view-reveal,
  .dbw{animation:none;}
  ::view-transition-old(browser-results),
  ::view-transition-new(browser-results){animation:none;}
}

/* ── MOBILE HEADER ── */
@media(max-width:768px){
  header{padding:0 0 14px;margin-bottom:18px;}
  .header-inner{display:grid;grid-template-columns:minmax(0,1fr) auto;grid-template-rows:52px auto auto;align-items:center;min-height:0;height:auto;gap:10px;}
  .logo-area,.header-right{display:contents;}
  .logo-link,.logo-link:any-link{grid-column:1;grid-row:1;display:flex;align-items:center;height:52px;align-self:center;}
  .header-controls{grid-column:2;grid-row:1;height:52px;margin-left:auto;align-self:center;}
  .logo-area .brand-logo{margin-bottom:0;}
  .logo-area .brand-logo .hex-lg{display:none;}
  .logo-area .brand-logo .hex-sm{display:block;}
  .logo-area .g{font-size:32px;}
  .logo-area .subtitle,.badge-source{display:none!important;}
  .toggle-label{display:none;}
  .user-name,.user-chevron{display:none;}
  .user-btn{padding:3px;border-radius:50%;width:auto;height:auto;border:1px solid var(--border2);background:var(--bg2);box-shadow:none;display:flex;place-items:initial;position:relative;}
  .user-btn::after{content:none;}
  .user-avatar{width:26px;height:26px;font-size:11px;}
}

/* ── MOBILE ── */
@media(max-width:779px){
  .container{padding:0 12px 0;}
  .controls{gap:7px;}
  .search-wrap{min-width:100%;max-width:100%;}
  select{flex:1;font-size:13px;}
  .bp-select{flex:1;min-width:150px;}
  input[type="text"]{font-size:14px;}
  .count-badge{margin-left:0;font-size:12px;}
  .page-title-compact{font-size:20px;margin-bottom:12px;}
  .table-wrap{display:none;}
  .card-list{display:flex;flex-direction:column;gap:10px;}
  .footer-inner{padding:18px 16px;}
  .footer-sub{flex-direction:column;align-items:flex-start;gap:4px;}
  .footer-legal{display:flex;align-items:center;column-gap:14px;row-gap:4px;flex-wrap:wrap;margin-left:0;}
  .footer-legal-terms{order:1;}
  .footer-sep-terms{order:2;}
  .footer-legal-privacy{order:3;}
  .footer-sep-privacy{order:4;}
  .footer-cost-link{grid-column:auto;order:5;}
  .footer-cost-label-desktop{display:none;}
  .footer-cost-label-mobile,.footer-cost-mobile-sep{display:inline;}
  .footer-cost-mobile-sep{order:6;}
  .footer-copy{order:7;}
}
@media(min-width:780px){.card-list{display:none;}}

/* ── MOBILE CARDS ── */
.card-list{border-radius:12px;border:1px solid var(--border);background:var(--bg2);overflow:hidden;transition:background 0.3s,border-color 0.3s;}
.kit-card{border-bottom:1px solid var(--border);padding:12px;transition:border-color 0.3s;}
.kit-card:last-child{border-bottom:none;}
.card-row1{display:flex;align-items:flex-start;gap:10px;}
.card-thumb{width:auto;height:170px;border-radius:7px;object-fit:contain;flex-shrink:0;border:1px solid var(--border2);background:var(--bg3);}
.card-thumb-landscape{width:165px;height:auto;border-radius:7px;object-fit:contain;flex-shrink:0;border:1px solid var(--border2);background:var(--bg3);}
.card-main{flex:1;min-width:0;}
.card-compact-specs{display:none;}
.card-row2{display:flex;flex-wrap:wrap;gap:6px;margin-top:10px;padding-top:9px;border-top:1px solid var(--border);}
.chip{display:flex;flex-direction:column;gap:2px;background:var(--bg3);border:1px solid var(--border);border-radius:6px;padding:5px 9px;min-width:74px;}
.chip-label{font-size:9px;text-transform:uppercase;letter-spacing:0.1em;color:var(--text3);font-weight:600;}
.chip-value{font-family:'DM Mono',monospace;font-size:12px;color:var(--text2);}
.chip-value.accent{color:var(--text);font-weight:500;}
.chip.wide{min-width:150px;flex:1;}
@media(max-width:779px){
  body:not(.view-large) .kit-card .card-row2{display:none;}
  body:not(.view-large) .kit-card .card-compact-specs{
    display:flex;
    align-items:center;
    flex-wrap:wrap;
    gap:7px;
    margin-top:7px;
    font-size:11px;
    line-height:1.35;
    color:var(--text3);
  }
}

/* ══════════════════════════════════════════════════════
   ADD-TO-BOX MODAL
   ══════════════════════════════════════════════════════ */
#boxModal{
  display:none;position:fixed;inset:0;
  background:var(--modal-overlay);
  z-index:9998;align-items:center;justify-content:center;
  padding:16px;
}
#boxModal.open{display:flex;}
.bm-panel{
  background:var(--bg2);border:1px solid var(--border2);
  border-radius:16px;width:100%;max-width:460px;
  max-height:90vh;overflow:hidden;
  display:flex;flex-direction:column;
  box-shadow:0 24px 60px rgba(0,0,0,0.45);
  animation:bmSlideIn 0.22s cubic-bezier(.4,0,.2,1) both;
}
@keyframes bmSlideIn{from{opacity:0;transform:translateY(14px)}to{opacity:1;transform:translateY(0)}}
.bm-header{
  display:flex;align-items:center;justify-content:space-between;
  padding:18px 20px 14px;border-bottom:1px solid var(--border);
  flex-shrink:0;
}
.bm-title{font-size:15px;font-weight:600;color:var(--text);}
.bm-subtitle{font-size:11px;color:var(--text3);margin-top:2px;}
.bm-close{
  background:none;border:none;cursor:pointer;color:var(--text3);
  padding:4px;border-radius:6px;transition:color 0.15s,background 0.15s;line-height:1;
}
.bm-close:hover{color:var(--text);background:var(--bg3);}
.bm-body{overflow-y:auto;padding:14px 20px;flex:1;}
.bm-body::-webkit-scrollbar{width:4px;}
.bm-body::-webkit-scrollbar-thumb{background:var(--scrollbar-thumb);border-radius:2px;}
.bm-kit-preview{
  display:flex;align-items:center;gap:10px;
  padding:10px 12px;background:var(--bg3);border:1px solid var(--border);
  border-radius:8px;margin-bottom:14px;
}
.bm-kit-thumb{width:48px;height:48px;border-radius:6px;object-fit:cover;flex-shrink:0;border:1px solid var(--border2);background:var(--bg2);}
.bm-kit-thumb-err{width:48px;height:48px;border-radius:6px;flex-shrink:0;background:var(--bg3);border:1px solid var(--border);display:flex;align-items:center;justify-content:center;color:var(--text3);font-size:18px;}
.bm-kit-info{flex:1;min-width:0;}
.bm-kit-name{font-size:13px;font-weight:600;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.bm-kit-meta{font-size:11px;color:var(--text3);margin-top:2px;}
.bm-section-label{font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:0.12em;color:var(--text3);margin-bottom:8px;}
.bm-box-list{display:flex;flex-direction:column;gap:0;margin-bottom:16px;border:1px solid var(--border2);border-radius:10px;overflow:hidden;}
.bm-box-item{
  display:flex;align-items:center;gap:10px;
  padding:12px 14px;
  border-bottom:1px solid var(--border2);background:var(--bg2);
  cursor:pointer;transition:background 0.15s;
}
.bm-box-item:last-child{border-bottom:none;}
.bm-box-item:hover{background:var(--bg3);border-radius:8px;}
.bm-box-icon{
  width:34px;height:34px;border-radius:7px;flex-shrink:0;
  background:rgba(201,169,110,0.08);border:1px solid rgba(201,169,110,0.15);
  display:flex;align-items:center;justify-content:center;color:var(--accent-text);
}
.bm-box-item.has-kit{border-radius:8px;}
.bm-box-details{flex:1;min-width:0;}
.bm-box-name{font-size:13px;font-weight:600;color:var(--text);}
.bm-box-dims{font-family:'DM Mono',monospace;font-size:11px;color:var(--text3);margin-top:1px;}
.bm-box-right{display:flex;flex-direction:column;align-items:flex-end;gap:4px;flex-shrink:0;}
.bm-qty-wrap{display:flex;align-items:center;gap:4px;margin-top:6px;}
.bm-qty-btn{width:22px;height:22px;border-radius:5px;border:1px solid var(--border2);background:var(--bg);color:var(--text2);cursor:pointer;font-family:'DM Sans',sans-serif;font-size:14px;font-weight:600;display:flex;align-items:center;justify-content:center;transition:background 0.12s,border-color 0.12s;flex-shrink:0;line-height:1;user-select:none;}
.bm-qty-btn:hover{border-color:rgba(201,169,110,0.4);color:var(--accent-text);background:rgba(201,169,110,0.06);}
.bm-qty-input{width:38px;height:22px;text-align:center;background:var(--bg);border:1px solid var(--border2);border-radius:5px;color:var(--text);font-family:'DM Sans',sans-serif;font-size:12px;outline:none;padding:0;-moz-appearance:textfield;}
.bm-qty-input::-webkit-outer-spin-button,.bm-qty-input::-webkit-inner-spin-button{-webkit-appearance:none;}
.bm-qty-input:focus{border-color:rgba(201,169,110,0.4);}
.bm-box-count{font-size:10px;font-weight:600;padding:2px 7px;border-radius:4px;background:rgba(201,169,110,0.1);color:var(--accent-text);border:1px solid rgba(201,169,110,0.2);white-space:nowrap;}
.bm-box-kit-tag{font-size:9px;font-weight:700;padding:1px 5px;border-radius:3px;background:rgba(34,197,94,0.12);color:var(--success-text);border:1px solid rgba(34,197,94,0.25);white-space:nowrap;}
.bm-empty{text-align:center;padding:24px 12px;color:var(--text3);font-size:13px;border:1px dashed var(--border2);border-radius:8px;margin-bottom:16px;}
.bm-empty svg{opacity:0.3;display:block;margin:0 auto 8px;}
.bm-loading{display:flex;align-items:center;gap:10px;padding:16px;color:var(--text3);font-size:13px;margin-bottom:12px;}
.bm-spinner{width:18px;height:18px;border-radius:50%;flex-shrink:0;border:2px solid var(--border2);border-top-color:var(--accent-text);animation:spin 0.7s linear infinite;}
.bm-create{border:1px solid var(--border2);border-radius:10px;overflow:hidden;margin-bottom:12px;}
.bm-create-toggle{display:flex;align-items:center;gap:8px;padding:11px 14px;cursor:pointer;user-select:none;font-family:'DM Sans',sans-serif;font-size:13px;font-weight:500;color:var(--accent-text);background:rgba(201,169,110,0.04);border:none;width:100%;text-align:left;transition:background 0.15s;}
.bm-create-toggle:hover{background:rgba(201,169,110,0.1);}
.bm-create-toggle svg{flex-shrink:0;}
.bm-create-toggle .bm-chevron{margin-left:auto;transition:transform 0.2s;opacity:0.5;}
.bm-create-toggle.open .bm-chevron{transform:rotate(180deg);}
.bm-create-form{
  max-height:0;overflow:hidden;
  padding:0 14px;border-top:0px solid var(--border);background:var(--bg);
  transition:max-height 0.28s cubic-bezier(0.4,0,0.2,1),padding 0.2s,border-top-width 0.2s;
}
.bm-create-form.open{max-height:400px;padding:14px;border-top:1px solid var(--border);}
.bm-form-grid{display:grid;grid-template-columns:1fr 1fr 1fr;gap:8px;margin-bottom:10px;}
.bm-form-group{display:flex;flex-direction:column;gap:4px;}
.bm-label{font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:0.1em;color:var(--text3);}
.bm-input{padding:8px 10px;background:var(--input-bg);border:1px solid var(--border2);border-radius:6px;color:var(--text);font-family:'DM Sans',sans-serif;font-size:13px;outline:none;transition:border-color 0.2s,box-shadow 0.2s;width:100%;}
.bm-input:focus{border-color:rgba(201,169,110,0.5);box-shadow:0 0 0 3px rgba(201,169,110,0.08);}
.bm-input::placeholder{color:var(--text3);}
.bm-form-name{margin-bottom:10px;}
.bm-create-actions{display:flex;gap:8px;justify-content:flex-end;}
.bm-btn{padding:8px 16px;border-radius:6px;font-family:'DM Sans',sans-serif;font-size:13px;font-weight:600;cursor:pointer;border:none;transition:opacity 0.15s,transform 0.1s;}
.bm-btn:active{transform:scale(0.97);}
.bm-btn-primary{background:linear-gradient(135deg,var(--accent2),var(--accent));background-color:var(--accent);color:#000;}
.bm-btn-primary:hover{opacity:0.9;}
.bm-btn-primary:disabled{opacity:0.45;cursor:not-allowed;}
html[data-theme="light"] .bm-btn-primary{background:var(--accent-text);background-color:var(--accent-text);color:#fff;}
.bm-btn-ghost{background:var(--bg3);color:var(--text2);border:1px solid var(--border2);}
.bm-btn-ghost:hover{background:var(--bg2);}
.bm-feedback{padding:9px 12px;border-radius:6px;font-size:12px;margin-bottom:10px;display:none;gap:6px;align-items:flex-start;border:1px solid;}
.bm-feedback.error{background:var(--error-bg);border-color:var(--error-border);color:var(--error-text);}
.bm-feedback.success{background:var(--success-bg);border-color:var(--success-border);color:var(--success-text);}
.bm-hint{font-size:11px;color:var(--accent-text);background:rgba(201,169,110,0.06);border:1px solid rgba(201,169,110,0.25);border-radius:6px;padding:8px 10px;margin-bottom:12px;line-height:1.5;}
@media(max-width:779px){
  #boxModal{align-items:flex-end;padding:0;}
  .bm-panel{border-radius:16px 16px 0 0;max-width:100%;max-height:85vh;animation:bmSlideUp 0.28s cubic-bezier(.4,0,.2,1) both;}
  @keyframes bmSlideUp{from{transform:translateY(100%)}to{transform:translateY(0)}}
  .card-list{background:transparent;border:none;overflow:visible;}
  .kit-card{background:var(--bg2);border:1px solid var(--border);border-radius:10px;}
  .kit-card:last-child{border-bottom:1px solid var(--border);}
}
/* ── UTILITIES & SHARED COMPONENTS ── */
/* Utility */
.hidden{display:none!important;}
/* Header */
.header-controls{display:flex;align-items:center;gap:14px;justify-content:flex-end;}
/* Pages with the user menu (desktop only): drop the toggle + user menu 7px so
   the menu's bottom edge aligns with the BOXPLA logo's letter baseline. Measured
   gap is 7px on browser/collection/boxes/settings (shared header geometry: 48px
   logo baseline 45px below header top; 38px user button at top 24 -> bottom 62;
   +7 = 69 = baseline). :has(#userArea) targets exactly the user-menu pages and
   excludes privacy/terms (back-link, no menu). Desktop-only: mobile uses a round
   avatar and a different header layout. */
@media(min-width:780px){
  .header-controls:has(#userArea){margin-top:7px;}
  /* Reserve the exact height of the logged-in user button so the row doesn't
     shift while initUserMenu() is pending or when only the login button shows. */
  #userArea{min-height:38px;display:flex;align-items:center;}
  /* Legal pages (privacy/terms): the toggle + back-link cluster is shorter
     (~30px, bottom at 54), so it needs 15px to reach the same logo baseline (69).
     :has(.back-link) targets exactly these two pages. */
  .header-controls:has(.back-link){margin-top:15px;}
}
/* Box-badge variant */
.count-badge--box{color:var(--accent-text);border-color:rgba(201,169,110,0.3);background:rgba(201,169,110,0.08);cursor:pointer;text-decoration:none;}
.count-badge--box:hover,.count-badge--box:visited{color:var(--accent-text);text-decoration:none;}
/* Collect modal icon backgrounds */
.co-icon--wishlist{background:rgba(236,72,153,0.12);}
.co-icon--owned{background:rgba(34,197,94,0.12);}
.co-icon--building{background:rgba(234,179,8,0.12);}
.co-icon--built{background:rgba(59,130,246,0.12);}
.co-icon--remove{background:var(--bg3);}
/* Box modal extras */
.bm-kit-dims{font-family:'DM Mono',monospace;font-size:10px;color:var(--text3);margin-top:2px;}
.bm-preview-qty{display:flex;flex-direction:column;align-items:flex-end;gap:4px;flex-shrink:0;}
.bm-qty-label{font-size:9px;font-weight:600;text-transform:uppercase;letter-spacing:0.1em;color:var(--text3);}
#bmGlobalQty{width:42px;height:26px;font-size:13px;}
.bm-dims-label{font-size:11px;color:var(--text3);margin-bottom:8px;}
/* Avatar */
.avatar-img{width:100%;height:100%;object-fit:cover;border-radius:50%;}
/* ── COLLECTION TABS ── */
.tabs{display:flex;gap:4px;margin-bottom:20px;flex-wrap:wrap;}
.tab{display:inline-flex;align-items:center;gap:6px;padding:7px 14px;border-radius:20px;font-size:12px;font-weight:600;cursor:pointer;user-select:none;border:1px solid var(--border2);background:var(--bg2);color:var(--text3);transition:all 0.15s;}
.tab:hover{border-color:var(--accent-text);color:var(--text);}
.tab.active{border-color:var(--accent-text);background:rgba(201,169,110,0.1);color:var(--accent-text);}
.tab .tab-count{font-size:10px;background:var(--bg3);padding:1px 5px;border-radius:8px;font-weight:700;}
.tab.active .tab-count{background:rgba(201,169,110,0.2);}
.tab-wishlist.active{border-color:var(--pink-text);background:rgba(236,72,153,0.08);color:var(--pink-text);}
.tab-wishlist.active .tab-count{background:rgba(236,72,153,0.15);}
.tab-owned.active{border-color:var(--success-text);background:rgba(34,197,94,0.08);color:var(--success-text);}
.tab-owned.active .tab-count{background:rgba(34,197,94,0.15);}
.tab-building.active{border-color:var(--warn-text);background:rgba(234,179,8,0.08);color:var(--warn-text);}
.tab-building.active .tab-count{background:rgba(234,179,8,0.15);}
.tab-built.active{border-color:var(--blue-text);background:rgba(59,130,246,0.08);color:var(--blue-text);}
.tab-built.active .tab-count{background:rgba(59,130,246,0.15);}
@media(max-width:700px){.tabs{gap:6px;}.tab{font-size:11px;padding:6px 11px;}}
.avatar-initials{width:100%;height:100%;display:flex;align-items:center;justify-content:center;border-radius:50%;font-size:11px;font-weight:700;}
/* Classification pill clickable filter wrapper */
.pill-filter{cursor:pointer;}
/* Kit row / card templates */
.card-actions{display:flex;gap:8px;margin-top:10px;align-items:stretch;}
.kit-card .r-actions.card-actions{display:grid;grid-template-columns:repeat(auto-fit,minmax(0,1fr));width:100%;gap:8px;}
.kit-card .r-actions .r-collect,
.kit-card .r-actions .r-addbox,
.kit-card .r-actions .r-feedback{
  width:100%;
  min-width:0;
  height:40px;
  padding:0 6px;
  gap:4px;
  font-size:11px;
  white-space:nowrap;
}
.kit-card .r-actions .r-collect{padding:0 14px 0 6px;}
.kit-card .r-actions .r-feedback{opacity:1;}
.chip--grow{flex:1;}

/* ── DASHBOARD COMPACT WIDGET ── */
.dbw-updated{display:flex;align-items:center;gap:3px;font-size:9px;color:var(--text3);}
.dbw{width:330px;box-sizing:border-box;background:var(--bg2);border:1px solid var(--border2);border-radius:10px;padding:12px 14px 16px;flex-direction:column;overflow:hidden;display:flex;animation:rowIn 0.32s ease both;}
.dbw-top{display:flex;align-items:center;justify-content:space-between;height:14px;margin-bottom:5px;flex-shrink:0;}
.dbw-title{font-size:9px;font-weight:600;text-transform:uppercase;letter-spacing:.1em;color:var(--text3);}
.dbw-stats{display:flex;align-items:center;height:40px;margin-bottom:7px;flex-shrink:0;}
.dbw-stat{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;}
.dbw-num{font-family:'Saira Condensed',sans-serif;font-size:22px;font-weight:600;line-height:1;color:var(--accent-text);}
.dbw-lbl{display:flex;align-items:center;gap:2px;font-size:8px;font-weight:600;text-transform:uppercase;letter-spacing:.08em;color:var(--text3);}
.dbw-div{width:1px;height:26px;background:var(--border);flex-shrink:0;}
.dbw-bar{height:2px;border-radius:1px;background:var(--border2);display:flex;overflow:hidden;flex-shrink:0;}
.dbw-bar-seg{height:100%;width:0;transition:width .5s ease;}
/* expanded variant — collection page My Boxes widget */
/* Drop 6px so its top aligns with the collection (#dashWidget) widget on the
   opposite side — the left column's logo is taller than the right column's
   menu, leaving the boxes widget 6px higher without this. */
#colBoxWidget{margin-top:6px;}
.header-right>#dashWidget{margin-top:6px;}
.dbw--full{padding-bottom:12px;}
.dbw--full .dbw-bar{height:3px;border-radius:0;margin-top:auto;margin-left:-14px;margin-right:-14px;margin-bottom:-12px;}
.dbw-rank{display:flex;align-items:center;gap:10px;padding:8px 0 12px;border-top:1px solid var(--border);flex-shrink:0;min-height:63px;}
.cbw-hex{position:relative;width:36px;height:36px;flex-shrink:0;display:flex;align-items:center;justify-content:center;}
.cbw-hex svg{position:absolute;}
.cbw-hex-num{position:relative;z-index:1;font-family:'Saira Condensed',sans-serif;font-size:15px;font-weight:600;line-height:1;}
.cbw-info{flex:1;display:flex;flex-direction:column;gap:2px;min-width:0;}
.cbw-tier{font-size:7px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;border-radius:3px;padding:1px 5px;display:inline-flex;align-items:center;gap:3px;width:fit-content;margin-bottom:1px;}
.cbw-name-row{display:flex;align-items:baseline;gap:6px;}
.cbw-name{font-family:'Saira Condensed',sans-serif;font-size:14px;font-weight:600;line-height:1;white-space:nowrap;}
.cbw-max{font-size:7px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--warn-text);white-space:nowrap;flex-shrink:0;}
.cbw-desc{font-size:8px;color:var(--text3);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.cbw-lvl{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1px;flex-shrink:0;}
.cbw-lvl-num{font-family:'Saira Condensed',sans-serif;font-size:18px;font-weight:600;line-height:1;}
.cbw-lvl-of{font-size:7px;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:var(--text3);}
.t-starter .dbw-num,.t-starter .cbw-hex-num,.t-starter .cbw-name,.t-starter .cbw-lvl-num{color:var(--tier-neutral-text);}
.t-starter .cbw-tier{color:var(--tier-neutral-text);background:rgba(107,114,128,.12);border:1px solid rgba(107,114,128,.2);}
.t-bronze .dbw-num,.t-bronze .cbw-hex-num,.t-bronze .cbw-name,.t-bronze .cbw-lvl-num{color:var(--bronze-text);}
.t-bronze .cbw-tier{color:var(--bronze-text);background:rgba(180,83,9,.1);border:1px solid rgba(180,83,9,.25);}
.t-gold .cbw-hex-num,.t-gold .cbw-name,.t-gold .cbw-lvl-num{color:var(--accent-text);}
.t-gold .cbw-tier{color:var(--accent-text);background:rgba(201,169,110,.1);border:1px solid rgba(201,169,110,.25);}
.t-epic .dbw-num,.t-epic .cbw-hex-num,.t-epic .cbw-name,.t-epic .cbw-lvl-num{color:var(--purple-text);}
.t-epic .cbw-tier{color:var(--purple-text);background:rgba(139,92,246,.12);border:1px solid rgba(139,92,246,.3);}
.t-epic.dbw{box-shadow:0 0 0 1px rgba(139,92,246,.15),0 4px 20px rgba(139,92,246,.08);}
.t-legend .dbw-num,.t-legend .cbw-hex-num,.t-legend .cbw-name,.t-legend .cbw-lvl-num{background:linear-gradient(135deg,#fbbf24,#ef4444);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;}
.t-legend .cbw-tier{color:var(--warn-text);background:rgba(251,191,36,.1);border:1px solid rgba(251,191,36,.3);}
.t-legend.dbw{border-color:rgba(251,191,36,.25);box-shadow:0 0 0 1px rgba(251,191,36,.1),0 4px 24px rgba(251,191,36,.1);}
/* GOD tier (level 10, 1000+) — iridescent, animated, maximum impact */
.t-god .dbw-num,.t-god .cbw-hex-num,.t-god .cbw-name,.t-god .cbw-lvl-num{background:linear-gradient(135deg,#fbbf24,#f472b6,#818cf8,#22d3ee,#fbbf24);background-size:300% 300%;-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;animation:godShift 4s ease-in-out infinite;}
.t-god .cbw-tier{color:#fff;background:linear-gradient(135deg,#fbbf24,#f472b6,#818cf8,#22d3ee);background-size:300% 300%;border:1px solid rgba(255,255,255,.35);animation:godShift 4s ease-in-out infinite;}
.t-god.dbw{border-color:rgba(129,140,248,.45);animation:godGlow 3s ease-in-out infinite;}
@keyframes godShift{0%,100%{background-position:0% 50%}50%{background-position:100% 50%}}
@keyframes godGlow{0%,100%{box-shadow:0 0 0 1px rgba(251,191,36,.25),0 0 22px rgba(129,140,248,.25),0 4px 30px rgba(244,114,182,.18);}50%{box-shadow:0 0 0 1px rgba(34,211,238,.35),0 0 34px rgba(129,140,248,.45),0 6px 44px rgba(244,114,182,.3);}}
@media(prefers-reduced-motion:reduce){.t-god .dbw-num,.t-god .cbw-hex-num,.t-god .cbw-name,.t-god .cbw-lvl-num,.t-god .cbw-tier,.t-god.dbw{animation:none;}}
@media(max-width:768px){
  .dbw{grid-column:1/-1;display:grid;grid-template-columns:62px minmax(0,1fr) auto;align-items:center;gap:8px;width:100%;min-height:48px;margin-top:0;padding:6px 10px;border-radius:9px;}
  .dbw--full{grid-template-columns:62px minmax(0,1fr) 106px;gap:6px;}
  .dbw::before{content:attr(data-mobile-title);font-size:8px;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--text3);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
  .dbw-top,.dbw-bar{display:none;}
  .dbw-stats{height:auto;margin:0;min-width:0;overflow:hidden;}
  .dbw--full .dbw-stats{display:grid;grid-template-columns:minmax(0,1fr) 1px minmax(0,1fr) 1px minmax(0,1fr) 1px minmax(0,1fr) 1px minmax(0,1fr);align-items:center;}
  .dbw-stat{flex-direction:column;gap:1px;min-width:0;}
  .dbw--full .dbw-stat{width:100%;}
  .dbw-num{font-size:17px;}
  .dbw-lbl{font-size:6.5px;letter-spacing:.04em;white-space:nowrap;line-height:1;}
  .dbw-lbl svg{display:none;}
  .dbw-div{height:24px;}
  .dbw--full .dbw-div{width:1px;justify-self:center;}
  .dbw-rank{grid-column:3;display:flex;align-items:center;gap:5px;min-height:0;padding:0;border-top:none;overflow:hidden;}
  .dbw--full .dbw-rank{width:106px;justify-self:end;}
  .dbw-rank .cbw-hex{width:26px;height:26px;}
  .dbw-rank .cbw-hex svg{width:26px;height:26px;}
  .dbw-rank .cbw-hex-num{font-size:11px;}
  .dbw-rank .cbw-info{display:flex;gap:1px;width:70px;max-width:70px;flex:0 0 70px;}
  .dbw-rank .cbw-tier{font-size:6px;padding:1px 4px;max-width:70px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;}
  .dbw-rank .cbw-name-row{display:block;min-width:0;}
  .dbw-rank .cbw-name{display:block;font-size:12px;max-width:70px;overflow:hidden;text-overflow:ellipsis;}
  .dbw-rank .cbw-desc,.dbw-rank .cbw-lvl{display:none;}
  #colBoxWidget,.header-right>#dashWidget{margin-top:0;}
  .dbw--full .dbw-bar{display:none;}
}
@media(max-width:420px){
  .dbw--full{grid-template-columns:58px minmax(0,1fr) 98px;gap:5px;padding-left:8px;padding-right:8px;}
  .dbw--full .dbw-rank{width:98px;}
  .dbw-rank .cbw-info{width:62px;max-width:62px;flex-basis:62px;}
  .dbw-rank .cbw-tier,.dbw-rank .cbw-name{max-width:62px;}
}

/* ══════════════════════════════════════════════════════
   RATE / REPORT MODAL (fb-) — opened from the desktop
   table's "Rate · Report" button
   ══════════════════════════════════════════════════════ */
.fb-overlay{position:fixed;inset:0;z-index:10000;background:var(--modal-overlay);backdrop-filter:blur(5px);display:flex;align-items:center;justify-content:center;opacity:0;pointer-events:none;transition:opacity .2s;}
.fb-overlay.open{opacity:1;pointer-events:all;}
.fb-modal{width:440px;max-width:calc(100vw - 32px);background:var(--bg2);border:1px solid var(--border2);border-radius:16px;overflow:hidden;transform:translateY(10px) scale(0.988);transition:transform .2s;max-height:92vh;display:flex;flex-direction:column;}
.fb-overlay.open .fb-modal{transform:none;}
.fb-kit{display:flex;align-items:center;gap:13px;padding:18px 20px 0;}
.fb-kit-thumb{width:44px;height:52px;object-fit:contain;border-radius:7px;border:1px solid var(--border2);background:var(--bg3);flex-shrink:0;}
.fb-kit-thumb.land{width:64px;height:44px;}
.fb-kit-info{flex:1;min-width:0;}
.fb-kit-name{font-weight:600;font-size:14px;color:var(--text);line-height:1.3;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.fb-kit-sub{font-size:12px;color:var(--text3);margin-top:2px;display:flex;align-items:center;gap:7px;}
.fb-kit-no{font-family:'DM Mono',monospace;font-size:11px;color:var(--text3);}
.fb-close{width:30px;height:30px;border-radius:8px;border:1px solid var(--border);background:transparent;color:var(--text3);cursor:pointer;display:flex;align-items:center;justify-content:center;flex-shrink:0;align-self:flex-start;transition:color .12s,border-color .12s;}
.fb-close:hover{color:var(--text);border-color:var(--border2);}
.fb-tabs{display:flex;padding:14px 20px 0;border-bottom:1px solid var(--border);}
.fb-tab{flex:1;height:36px;border:none;background:transparent;font-family:'DM Sans',sans-serif;font-size:12.5px;font-weight:600;color:var(--text3);cursor:pointer;border-bottom:2px solid transparent;transition:color .15s,border-color .15s;margin-bottom:-1px;display:flex;align-items:center;justify-content:center;gap:7px;}
.fb-tab:hover{color:var(--text2);}
.fb-tab.active{color:var(--text);border-bottom-color:var(--accent-text);}
.fb-body{padding:20px;}
.fb-panel{display:none;}
.fb-panel.active{display:block;}
.fb-panel-label{font-size:12.5px;color:var(--text2);line-height:1.55;margin-bottom:14px;}
.fb-score-row{display:flex;gap:5px;margin-bottom:8px;}
.fb-snum{flex:1;height:38px;border-radius:8px;border:1px solid var(--border2);background:var(--bg3);color:var(--text2);font-family:'DM Mono',monospace;font-size:14px;font-weight:500;cursor:pointer;transition:border-color .12s,color .12s,background .12s;}
.fb-snum:hover{border-color:rgba(201,169,110,0.4);color:var(--accent-text);}
.fb-snum.selected{background:var(--accent);border-color:var(--accent-text);color:#000;}
html[data-theme="light"] .fb-snum.selected{background:var(--accent-text);border-color:var(--accent-text);color:#fff;}
.fb-score-poles{display:flex;justify-content:space-between;font-size:11px;color:var(--text3);margin-bottom:4px;padding:0 2px;}
.fb-error{margin-top:10px;font-size:12px;color:var(--error-text);background:var(--error-bg);border:1px solid var(--error-border);border-radius:7px;padding:8px 10px;line-height:1.5;}
.fb-rp-hint{font-size:12px;color:var(--text3);line-height:1.55;margin-bottom:12px;padding-bottom:12px;border-bottom:1px solid var(--border);}
.fb-rp-fields{display:flex;flex-direction:column;gap:2px;margin-bottom:14px;}
.fb-rp-row{border-radius:8px;border:1px solid transparent;background:transparent;transition:border-color .15s,background .15s;overflow:hidden;}
.fb-rp-row.flagged{border-color:rgba(239,68,68,0.28);background:rgba(239,68,68,0.04);}
.fb-rp-row-main{display:flex;align-items:center;gap:10px;padding:8px 10px;cursor:pointer;}
.fb-rp-row-info{flex:1;min-width:0;}
.fb-rp-field-name{display:block;font-size:9.5px;font-weight:600;text-transform:uppercase;letter-spacing:0.1em;color:var(--text3);}
.fb-rp-field-val{display:block;font-size:12.5px;color:var(--text2);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-top:1px;max-width:270px;font-family:'DM Mono',monospace;}
.fb-rp-flag{width:26px;height:26px;border-radius:7px;border:1px solid var(--border2);background:transparent;color:var(--text3);cursor:pointer;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:border-color .15s,color .15s,background .15s;}
.fb-rp-flag:hover{border-color:rgba(239,68,68,0.4);color:var(--danger-text);}
.fb-rp-row.flagged .fb-rp-flag{border-color:rgba(239,68,68,0.5);background:rgba(239,68,68,0.1);color:var(--danger-text);}
.fb-rp-row-input{display:none;padding:0 10px 10px;}
.fb-rp-row.flagged .fb-rp-row-input{display:block;}
.fb-rp-correction{width:100%;background:var(--bg3);border:1px solid rgba(239,68,68,0.25);border-radius:7px;color:var(--text);font-family:'DM Sans',sans-serif;font-size:12.5px;padding:7px 10px;outline:none;transition:border-color .15s;}
.fb-rp-correction::placeholder{color:var(--text3);}
.fb-rp-correction:focus{border-color:rgba(239,68,68,0.5);}
.fb-rp-notes{padding-top:12px;border-top:1px solid var(--border);}
.fb-field-label{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:0.1em;color:var(--text3);margin-bottom:7px;}
.fb-field-label-opt{font-weight:400;text-transform:none;letter-spacing:0;color:var(--text3);}
.fb-textarea{width:100%;background:var(--bg3);border:1px solid var(--border);border-radius:9px;color:var(--text);font-family:'DM Sans',sans-serif;font-size:13px;padding:10px 12px;resize:none;outline:none;transition:border-color .15s;line-height:1.5;}
.fb-textarea::placeholder{color:var(--text3);}
.fb-textarea:focus{border-color:var(--border2);}
#fbPanelReport.active{display:flex;flex-direction:column;flex:1;min-height:0;}
#fbPanelReport .fb-body{flex:1;min-height:0;overflow-y:auto;padding:16px 20px;}
#fbPanelReport .fb-body::-webkit-scrollbar{width:4px;}
#fbPanelReport .fb-body::-webkit-scrollbar-thumb{background:var(--scrollbar-thumb);border-radius:2px;}
#fbPanelReport .fb-footer{flex-shrink:0;}
.fb-footer{padding:0 20px 18px;display:flex;gap:9px;}
.fb-btn-submit{flex:1;height:40px;border-radius:9px;background:var(--accent);border:none;color:#000;font-family:'DM Sans',sans-serif;font-size:13px;font-weight:600;cursor:pointer;transition:opacity .15s;}
.fb-btn-submit:hover{opacity:0.88;}
.fb-btn-submit:disabled{opacity:0.35;cursor:not-allowed;}
html[data-theme="light"] .fb-btn-submit{background:var(--accent-text);color:#fff;}
.fb-btn-cancel{height:40px;padding:0 16px;border-radius:9px;background:transparent;border:1px solid var(--border2);color:var(--text3);font-family:'DM Sans',sans-serif;font-size:13px;cursor:pointer;transition:color .12s;}
.fb-btn-cancel:hover{color:var(--text2);}
.fb-confirm{display:none;text-align:center;padding:28px 24px 6px;}
.fb-confirm.active{display:block;}
.fb-confirm-icon{width:50px;height:50px;border-radius:50%;background:rgba(34,197,94,0.1);border:1px solid rgba(34,197,94,0.25);display:flex;align-items:center;justify-content:center;margin:0 auto 14px;}
.fb-confirm-title{font-family:'Saira Condensed',sans-serif;font-size:20px;font-weight:600;color:var(--text);margin-bottom:6px;}
.fb-confirm-sub{font-size:13px;color:var(--text3);line-height:1.6;}
.fb-confirm-footer{padding:20px 20px 18px;}
.fb-confirm-footer .fb-btn-submit{width:100%;}

@media (max-width:640px){
  .fb-overlay{
    align-items:flex-end;
    padding-top:max(8px,env(safe-area-inset-top));
  }
  .fb-modal{
    width:100%;
    max-width:100%;
    border-radius:16px 16px 0 0;
    max-height:calc(100vh - 8px);
    max-height:calc(100svh - 8px);
    max-height:calc(100dvh - 8px);
  }
  .fb-kit{padding:14px 16px 0;}
  .fb-tabs{padding:12px 16px 0;}
  #fbPanelReport .fb-body{padding:14px 16px;}
  .fb-footer{
    padding:10px 16px max(18px,calc(env(safe-area-inset-bottom) + 18px));
    border-top:1px solid var(--border);
    background:var(--bg2);
  }
  .fb-confirm-footer{padding:16px 16px max(18px,calc(env(safe-area-inset-bottom) + 18px));}
}

