/* Apogea — app, auth, panels, cards, modals, responsive UI */

/* AUTH */
.auth-wrap{min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:calc(env(safe-area-inset-top, 44px) + 40px) 24px calc(env(safe-area-inset-bottom, 34px) + 20px)}
.auth-logo{font-size:56px;margin-bottom:16px}
.auth-title{font-family:'Cormorant Garamond',serif;font-size:32px;font-weight:300;color:var(--gold);letter-spacing:.1em;text-transform:uppercase;margin-bottom:6px}
.auth-sub{font-size:12px;color:var(--t3);letter-spacing:.2em;text-transform:uppercase;margin-bottom:40px}
.auth-card{background:var(--bg-card);border:1px solid var(--b2);border-radius:20px;padding:28px 24px;width:100%;max-width:340px;box-shadow:var(--shadow)}
.auth-tabs{display:flex;gap:0;margin-bottom:24px;border-bottom:1px solid var(--b2)}
.auth-tab{flex:1;padding:10px;text-align:center;font-size:13px;color:var(--t3);cursor:pointer;border-bottom:2px solid transparent;margin-bottom:-1px;background:none;border-top:none;border-left:none;border-right:none;font-family:'DM Sans',sans-serif;-webkit-appearance:none}
.auth-tab.on{color:var(--gold);border-bottom-color:var(--gold)}
.auth-field{margin-bottom:16px}
.auth-field label{font-size:10px;color:var(--t3);letter-spacing:.15em;text-transform:uppercase;display:block;margin-bottom:6px}
.auth-field input{width:100%;background:var(--bg-input);border:1px solid var(--b2);border-radius:12px;padding:13px 16px;color:var(--t1);font-size:15px;font-family:'DM Sans',sans-serif;outline:none;-webkit-appearance:none}
.auth-field input::placeholder{color:var(--t3)}
.auth-btn{width:100%;border-radius:12px;padding:15px;font-size:15px;font-weight:500;cursor:pointer;font-family:'DM Sans',sans-serif;border:none;-webkit-appearance:none;margin-top:8px}
.auth-btn-gold{background:linear-gradient(145deg,var(--gold),var(--gold-dim));color:#080608;box-shadow:0 4px 20px rgba(212,168,75,.3)}
.auth-err{font-size:12px;color:var(--red);margin-top:10px;text-align:center;line-height:1.5}
.auth-ok{font-size:12px;color:var(--green);margin-top:10px;text-align:center;line-height:1.5}
.auth-info{font-size:11px;color:var(--t3);margin-top:8px;text-align:center;line-height:1.5;padding:0 8px}

/* HEADER */
.hdr{
  background:linear-gradient(180deg,rgba(45,8,20,.98) 0%,rgba(61,12,31,.85) 100%);
  padding:calc(env(safe-area-inset-top, 0px) + 12px) 20px 12px;
  position:fixed;top:0;left:50%;transform:translateX(-50%);
  width:100%;max-width:480px;z-index:100;
  display:flex;justify-content:center;align-items:center;
  transition:transform .28s ease;
  backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);
  border-bottom:1px solid var(--b2);
}
.hdr.hidden{transform:translateX(-50%) translateY(-110%);}
.hdr-center{display:flex;flex-direction:column;align-items:center;gap:2px}
.hdr-name{font-family:'Cormorant Garamond',serif;font-size:22px;font-weight:300;letter-spacing:.15em;color:var(--gold);text-transform:uppercase;line-height:1}
.hdr-sub{font-size:9px;color:var(--t3);letter-spacing:.2em;text-transform:uppercase}
.hdr-btn{width:36px;height:36px;border-radius:11px;background:rgba(255,255,255,.05);border:1px solid var(--b2);color:var(--t2);font-size:15px;cursor:pointer;display:flex;align-items:center;justify-content:center;-webkit-appearance:none;position:absolute;right:20px;}

/* SYNC */
.sync-bar{height:2px;background:linear-gradient(90deg,var(--gold),var(--gold-dim));display:none;position:fixed;top:0;left:0;right:0;z-index:200;max-width:480px;margin:0 auto}
.sync-bar.show{display:block;animation:syncpulse 1s ease-in-out infinite}
@keyframes syncpulse{0%,100%{opacity:.4}50%{opacity:1}}

/* BOTTOM NAV */
.bottom-nav{position:fixed;bottom:0;left:50%;transform:translateX(-50%);width:100%;max-width:480px;background:rgba(45,8,20,.97);border-top:1px solid var(--b2);display:flex;padding:0 0 env(safe-area-inset-bottom, 0px);z-index:100;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px)}
.nav-item{flex:1;display:flex;flex-direction:column;align-items:center;padding:8px 4px 6px;cursor:pointer;gap:3px;background:none;border:none;font-family:'DM Sans',sans-serif;-webkit-appearance:none}
.nav-ico{font-size:18px;line-height:1;display:flex;align-items:center;justify-content:center;width:26px;height:26px;color:var(--t3)}.nav-item.on .nav-ico{color:#d4a84b}
.nav-lbl{font-size:9px;color:var(--t3);letter-spacing:.08em;text-transform:uppercase;font-weight:400}
.nav-item.on .nav-lbl{color:var(--gold)}
.nav-item.on .nav-ico{filter:none}

/* STATS */
.stats{display:flex;gap:10px;padding:0 16px}
.stat{flex:1;background:var(--bg-card);border:1px solid var(--b2);border-radius:16px;padding:14px 10px;text-align:center;box-shadow:var(--shadow)}
.stat-n{font-family:'Cormorant Garamond',serif;font-size:26px;font-weight:400;display:block;line-height:1}
.stat-l{font-size:9px;color:var(--t3);letter-spacing:.15em;text-transform:uppercase;margin-top:4px;display:block}

/* ALERT */
.alert-bar{display:none!important;visibility:hidden;margin:12px 16px 0;background:linear-gradient(135deg,rgba(232,184,75,.15),rgba(232,184,75,.08));border:1px solid rgba(232,184,75,.4);border-radius:12px;padding:10px 14px;font-size:12px;color:#f5d070;line-height:1.6;cursor:pointer}

/* SEARCH & FILTERS */
.search-wrap{padding:14px 16px 0}
.search{width:100%;background:var(--bg-card);border:1px solid var(--b2);border-radius:14px;padding:12px 16px;color:var(--t1);font-size:14px;font-family:'DM Sans',sans-serif;font-weight:300;outline:none;-webkit-appearance:none;box-shadow:var(--shadow)}
.search::placeholder{color:var(--t3)}
.filter-bar{display:flex;gap:6px;align-items:center;padding:10px 16px 0}
.filter-scroll{display:flex;gap:6px;overflow-x:auto;scrollbar-width:none;-webkit-overflow-scrolling:touch;flex:1}
.filter-scroll::-webkit-scrollbar{display:none}
.filter-more-btn{width:34px;height:34px;border-radius:10px;background:var(--bg-card);border:1px solid var(--b2);color:var(--t3);font-size:13px;cursor:pointer;display:flex;align-items:center;justify-content:center;flex-shrink:0;-webkit-appearance:none;font-family:'DM Sans',sans-serif}
.filter-more-btn.active{border-color:var(--gold);color:var(--gold)}
.filter-advanced{display:none;padding:0 16px}
.filter-advanced.show{display:block}
.ftag{background:var(--bg-card);color:var(--t2);border:1px solid var(--b2);border-radius:20px;padding:6px 14px;font-size:12px;cursor:pointer;white-space:nowrap;font-family:'DM Sans',sans-serif;-webkit-appearance:none;flex-shrink:0}
.ftag.on{background:linear-gradient(135deg,var(--gold),var(--gold-dim));color:#080608;border-color:var(--gold);font-weight:500}
.sort-btn{width:34px;height:34px;border-radius:10px;background:var(--bg-card);border:1px solid var(--b2);color:var(--t2);font-size:14px;cursor:pointer;display:flex;align-items:center;justify-content:center;flex-shrink:0;-webkit-appearance:none}

/* SECTION */
.sec-hdr{display:flex;align-items:center;gap:10px;padding:20px 16px 8px}
.sec-line{flex:1;height:1px;background:var(--b2)}
.sec-txt{font-size:10px;color:var(--t3);letter-spacing:.18em;text-transform:uppercase;white-space:nowrap}

/* VIN CARD */
.vcard{margin:0 16px 10px;background:rgba(255,255,255,.07);border:1px solid rgba(255,255,255,.12);border-radius:16px;padding:14px 16px;cursor:pointer;box-shadow:var(--shadow);display:flex;align-items:center;gap:12px}
.vcard:active{background:var(--bg-card2)}
.vcard.archived{opacity:.6;border-style:dashed}
.vcard-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0;margin-top:2px}
.vcard-body{flex:1;min-width:0}
.vcard-name{font-family:'Cormorant Garamond',serif;font-size:17px;font-weight:400;color:var(--t1);white-space:normal;overflow:hidden;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical}
.vcard-cuvee{font-size:13px;color:var(--gold-dim);font-style:italic;margin-top:2px;font-family:'Cormorant Garamond',serif}
.vcard-meta{font-size:11px;color:var(--t2);margin-top:3px;line-height:1.4}
.vcard-right{display:flex;flex-direction:column;align-items:flex-end;gap:6px;flex-shrink:0}
.sbadge{border-radius:8px;padding:3px 9px;font-size:10px;font-weight:500;white-space:nowrap}
.qbadge{font-family:'Cormorant Garamond',serif;font-size:24px;font-weight:400;color:var(--gold);line-height:1}
.qbadge-lbl{font-size:9px;color:var(--goldD);letter-spacing:.12em;text-transform:uppercase;text-align:right;font-weight:500}
.score-star{font-size:11px;color:var(--gold)}
.archived-badge{background:rgba(107,114,128,.15);color:var(--grey);border:1px solid rgba(107,114,128,.3);border-radius:8px;padding:3px 9px;font-size:10px}

/* EMPTY */
.empty{text-align:center;padding:60px 20px;color:var(--t2)}
.empty-ico{font-size:52px;margin-bottom:18px;display:block}
.empty-ttl{font-family:'Cormorant Garamond',serif;font-size:22px;font-weight:300;color:var(--t2)}
.empty-sub{font-size:12px;color:var(--t3);margin-top:8px;line-height:1.6}

/* FAB */
#fab{position:fixed;bottom:calc(72px + env(safe-area-inset-bottom));right:20px;width:56px;height:56px;border-radius:18px;background:linear-gradient(145deg,var(--gold),var(--gold-dim));color:#080608;border:none;font-size:26px;cursor:pointer;z-index:200;box-shadow:0 8px 32px rgba(212,168,75,.4);display:flex;align-items:center;justify-content:center;-webkit-appearance:none}
@media(min-width:480px){#fab{right:calc(50% - 220px)}}

/* PANELS */
.panel{position:fixed;top:0;left:0;right:0;bottom:0;padding-top:env(safe-area-inset-top,0px);padding-bottom:env(safe-area-inset-bottom,0px);background:var(--bg);z-index:300;display:none;flex-direction:column;max-width:480px;margin:0 auto;overflow:hidden}
.panel.show{display:flex}
.panel-hdr{background:linear-gradient(180deg,#2d0814,var(--bg));padding:calc(env(safe-area-inset-top)+16px) 20px 16px;border-bottom:1px solid var(--b2);display:flex;align-items:center;gap:12px;flex-shrink:0}
.back{width:38px;height:38px;border-radius:12px;background:var(--bg-card);border:1px solid var(--b2);color:var(--gold);font-size:18px;cursor:pointer;display:flex;align-items:center;justify-content:center;-webkit-appearance:none;flex-shrink:0;font-family:'DM Sans',sans-serif}
.panel-title{font-family:'Cormorant Garamond',serif;font-size:20px;font-weight:300;color:var(--gold);letter-spacing:.06em}
.panel-sub{font-size:11px;color:var(--t2);margin-top:2px}
.panel-body{overflow-y:auto;flex:1;-webkit-overflow-scrolling:touch;padding:0 0 40px}

/* FORM */
.fg{padding:16px 20px 0}
.fg label{font-size:10px;color:var(--t3);letter-spacing:.18em;text-transform:uppercase;display:block;margin-bottom:8px}
.fg input,.fg select,.fg textarea{width:100%;background:var(--bg-input);border:1px solid var(--b2);border-radius:14px;padding:13px 16px;color:var(--t1);font-size:15px;font-family:'DM Sans',sans-serif;font-weight:300;outline:none;-webkit-appearance:none;appearance:none;display:block;box-shadow:0 1px 8px rgba(0,0,0,.3)}
.fg input::placeholder,.fg textarea::placeholder{color:var(--t3)}
.fg textarea{resize:none;height:80px;line-height:1.5}
.fg select{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%235a5460' stroke-width='1.5' fill='none' stroke-linecap='round'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 16px center;padding-right:40px}
.fg select option{background:#111018;color:var(--t1)}
.fg select optgroup{color:var(--t3);font-size:11px}
.r2{display:flex;gap:10px}
.r2>div{flex:1}
.fg-opt label::after{content:" — optionnel";color:var(--t3);font-size:9px}

/* TYPE PILLS */
.type-lbl{font-size:10px;color:var(--t3);letter-spacing:.18em;text-transform:uppercase;padding:16px 20px 0;display:block}
.type-pills{display:flex;flex-wrap:wrap;gap:8px;padding:10px 20px 0}
.tpill{padding:8px 16px;border-radius:20px;font-size:13px;border:1px solid var(--b2);background:var(--bg-input);color:var(--t2);cursor:pointer;font-family:'DM Sans',sans-serif;-webkit-appearance:none}
.tpill.sel{border-color:var(--gold);color:var(--gold);background:rgba(212,168,75,.08);font-weight:500}

/* APO BOX */
.apo-box{margin:14px 20px 0;background:linear-gradient(135deg,rgba(212,168,75,.07),rgba(212,168,75,.03));border:1px solid rgba(212,168,75,.2);border-radius:16px;padding:14px 16px}
.apo-box-title{font-size:10px;color:var(--gold-dim);letter-spacing:.15em;text-transform:uppercase;margin-bottom:10px}
.apo-row{display:flex;justify-content:space-between;align-items:center;padding:5px 0}
.apo-lbl{font-size:12px;color:var(--t2)}
.apo-val{font-family:'Cormorant Garamond',serif;font-size:16px;color:var(--gold)}

/* ACCORDS BOX */
.accords-box{background:rgba(52,211,153,.05);border:1px solid rgba(52,211,153,.15);border-radius:16px;padding:14px 16px}
.accords-title{font-size:10px;color:rgba(52,211,153,.6);letter-spacing:.15em;text-transform:uppercase;margin-bottom:10px}
.accord-item{display:flex;align-items:flex-start;gap:8px;padding:4px 0;font-size:13px;color:var(--t2);line-height:1.4}
.conseils-box{background:rgba(212,168,75,.05);border:1px solid rgba(212,168,75,.2);border-radius:16px;padding:14px 16px}
.conseils-title{font-size:10px;color:var(--gold-dim);letter-spacing:.15em;text-transform:uppercase;margin-bottom:10px}
.conseil-row{display:flex;justify-content:space-between;align-items:center;padding:7px 0;border-bottom:1px solid var(--b3)}
.conseil-row:last-child{border-bottom:none}
.conseil-lbl{font-size:12px;color:var(--t2);display:flex;align-items:center;gap:6px}
.conseil-val{font-size:12px;color:var(--t1);font-weight:500;text-align:right;max-width:55%}

/* SCORE */
.score-wrap{position:relative}
.score-wrap input{padding-right:50px}
.score-unit{position:absolute;right:16px;top:50%;transform:translateY(-50%);color:var(--t3);font-size:13px;pointer-events:none}

/* AROME PILLS */
.arome-pills{display:flex;flex-wrap:wrap;gap:6px;padding:8px 0 0}
.arome-pill{padding:6px 12px;border-radius:16px;font-size:12px;border:1px solid var(--b2);background:var(--bg-input);color:var(--t2);cursor:pointer;font-family:'DM Sans',sans-serif;-webkit-appearance:none}
.arome-pill.sel{border-color:var(--gold-dim);color:var(--gold);background:rgba(212,168,75,.06)}

/* BUTTONS */
.brow{display:flex;gap:10px;padding:20px 20px 0}
.btn{flex:1;border-radius:14px;padding:15px 16px;font-size:15px;cursor:pointer;font-family:'DM Sans',sans-serif;font-weight:400;border:none;-webkit-appearance:none}
.btn-gold{background:linear-gradient(145deg,var(--gold),var(--gold-dim));color:#080608;font-weight:500;box-shadow:0 4px 20px rgba(212,168,75,.3)}
.btn-ghost{background:transparent;color:var(--gold);border:1px solid rgba(212,168,75,.35)!important}
.btn-red{background:linear-gradient(145deg,#c0392b,#922b21);color:#fff;box-shadow:0 4px 16px rgba(192,57,43,.25)}
.btn-green{background:transparent;color:var(--t2);border:1px solid var(--b2)!important}

/* DETAIL */
.st-banner{margin:16px 20px 0;border-radius:16px;padding:16px 18px;display:flex;justify-content:space-between;align-items:center;box-shadow:var(--shadow)}
.st-label{font-family:'Cormorant Garamond',serif;font-size:20px;font-weight:400}
.st-dates{font-size:12px;color:var(--t2);margin-top:4px}
.st-garde{font-size:11px;color:var(--t3);margin-top:3px}
.st-emoji{font-size:38px}
.drows{padding:0 20px;margin-top:4px}
.drow{display:flex;justify-content:space-between;align-items:center;padding:12px 0;border-bottom:1px solid var(--b3)}
.drow:last-child{border-bottom:none}
.dlbl{font-size:12px;color:var(--t2)}
.dval{font-size:14px;color:var(--t1);text-align:right;max-width:62%}

/* DEG CARD */
.deg-card{background:var(--bg-card);border:1px solid var(--b2);border-radius:16px;padding:16px;box-shadow:var(--shadow)}
.deg-card-hdr{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}
.deg-card-title{font-size:10px;color:var(--t3);letter-spacing:.15em;text-transform:uppercase}
.deg-card-actions{display:flex;gap:8px}
.deg-action-btn{background:none;border:none;color:var(--t3);font-size:13px;cursor:pointer;padding:2px 6px;border-radius:6px}
.deg-action-btn:active{background:var(--bg-card2)}
.deg-score{font-family:'Cormorant Garamond',serif;font-size:48px;color:var(--gold);font-weight:300;line-height:1;text-align:center;padding:8px 0}
.deg-score-lbl{font-size:10px;color:var(--t3);text-align:center;letter-spacing:.1em;text-transform:uppercase;margin-top:2px}
.deg-aromes{display:flex;flex-wrap:wrap;gap:6px;margin-top:10px}
.deg-arome{padding:4px 10px;border-radius:12px;font-size:11px;background:rgba(212,168,75,.08);border:1px solid rgba(212,168,75,.2);color:var(--gold)}
.deg-accord{margin-top:12px;padding:10px 12px;background:rgba(52,211,153,.06);border:1px solid rgba(52,211,153,.15);border-radius:10px;font-size:12px;color:var(--green);line-height:1.5}
.deg-comment{margin-top:10px;font-size:12px;color:var(--t2);font-style:italic;line-height:1.5}
.deg-list-sep{height:1px;background:var(--b2);margin:12px 0}

/* QTY */
.qty-zone{display:flex;align-items:center;justify-content:center;gap:32px;margin:16px 20px;padding:20px;background:var(--bg-card);border-radius:20px;border:1px solid var(--b2);box-shadow:var(--shadow)}
.qty-btn{background:var(--bg-card2);border:1px solid var(--b2);color:var(--gold);width:52px;height:52px;border-radius:16px;font-size:28px;cursor:pointer;display:flex;align-items:center;justify-content:center;-webkit-appearance:none;line-height:1}
.qty-btn:active{background:var(--bg-input)}
.qty-num{font-family:'Cormorant Garamond',serif;font-size:52px;color:var(--gold);font-weight:300;line-height:1;min-width:70px;text-align:center}
.qty-lbl{font-size:9px;color:var(--t3);letter-spacing:.2em;text-transform:uppercase;margin-top:4px;text-align:center}

/* STATS VIEW */
.stats-section{padding:16px 16px 0}
.stats-section-title{font-size:10px;color:var(--t3);letter-spacing:.18em;text-transform:uppercase;margin-bottom:12px}
.stat-big{background:var(--bg-card);border:1px solid var(--b2);border-radius:16px;padding:18px;box-shadow:var(--shadow);margin-bottom:10px}
.stat-big-n{font-family:'Cormorant Garamond',serif;font-size:48px;font-weight:300;color:var(--gold);line-height:1}
.stat-big-lbl{font-size:12px;color:var(--t2);margin-top:4px}
.stat-big-sub{font-size:11px;color:var(--t3);margin-top:2px}
.stats-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-bottom:10px}
.stat-card{background:var(--bg-card);border:1px solid var(--b2);border-radius:16px;padding:16px;box-shadow:var(--shadow)}
.stat-card-n{font-family:'Cormorant Garamond',serif;font-size:34px;font-weight:300;line-height:1}
.stat-card-lbl{font-size:11px;color:var(--t2);margin-top:4px}
.stat-card-sub{font-size:10px;color:var(--t3);margin-top:2px}
.top-list{background:var(--bg-card);border:1px solid var(--b2);border-radius:16px;padding:16px;box-shadow:var(--shadow);margin-bottom:10px}
.top-list-title{font-size:10px;color:var(--t3);letter-spacing:.18em;text-transform:uppercase;margin-bottom:12px}
.top-item{display:flex;justify-content:space-between;align-items:center;padding:8px 0;border-bottom:1px solid var(--b3)}
.top-item:last-child{border-bottom:none}
.top-item-name{font-size:13px;color:var(--t1)}
.top-item-val{font-family:'Cormorant Garamond',serif;font-size:18px;color:var(--gold)}
.top-item-lbl{font-size:10px;color:var(--t3);text-align:right}
.aboire-pill{
  width:100%;display:flex;align-items:center;gap:14px;
  background:var(--bg-card);border:1px solid var(--b2);
  border-radius:16px;padding:16px 18px;cursor:pointer;
  font-family:'DM Sans',sans-serif;-webkit-appearance:none;
  box-shadow:var(--shadow);text-align:left;
}
.aboire-pill.on{
  background:linear-gradient(135deg,rgba(212,168,75,.12),rgba(212,168,75,.06));
  border-color:rgba(212,168,75,.35);
}
.aboire-pill:active{opacity:.8}
.aboire-pill-ico{font-size:22px;flex-shrink:0}
.aboire-pill-body{flex:1}
.aboire-pill-title{
  font-family:'Cormorant Garamond',serif;
  font-size:18px;font-weight:400;color:var(--t1);line-height:1;
}
.aboire-pill.on .aboire-pill-title{color:var(--gold)}
.aboire-pill-sub{font-size:11px;color:var(--t3);margin-top:4px;letter-spacing:.04em}
.aboire-pill-arrow{font-size:22px;color:var(--t3);flex-shrink:0;line-height:1}
.aboire-pill.on .aboire-pill-arrow{color:var(--gold)}
.aboire-list-wrap{padding-top:4px}
#app-list div:active{background:var(--bg-card2)!important}
.apogee-list{background:var(--bg-card);border:1px solid rgba(212,168,75,.2);border-radius:16px;padding:16px;box-shadow:var(--shadow);margin-bottom:10px}
.apogee-list-title{font-size:10px;color:var(--gold-dim);letter-spacing:.18em;text-transform:uppercase;margin-bottom:12px}
.apogee-item{display:flex;justify-content:space-between;align-items:center;padding:8px 0;border-bottom:1px solid var(--b3);cursor:pointer}
.apogee-item:last-child{border-bottom:none}
.apogee-item:active{opacity:.7}
.apogee-item-name{font-size:13px;color:var(--t1)}
.apogee-item-meta{font-size:11px;color:var(--t2);margin-top:2px}
.apogee-item-right{text-align:right}
.apogee-year{font-family:'Cormorant Garamond',serif;font-size:18px;color:var(--green)}
.type-bar{display:flex;height:8px;border-radius:4px;overflow:hidden;margin-bottom:6px}
.type-bar-seg{height:100%;transition:none}
.type-legend{display:flex;flex-wrap:wrap;gap:8px}
.type-legend-item{display:flex;align-items:center;gap:5px;font-size:11px;color:var(--t2)}
.type-legend-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}

/* MENU */
.menu-bg{position:fixed;inset:0;background:rgba(0,0,0,.75);z-index:400;display:none}
.menu-bg.show{display:block}
.menu-sheet{position:fixed;bottom:0;left:50%;transform:translateX(-50%);width:100%;max-width:480px;background:var(--bg-sheet);border-top:1px solid var(--b1);border-radius:24px 24px 0 0;z-index:401;display:none;flex-direction:column;max-height:85vh}
.menu-sheet.show{display:flex}
.menu-sheet-header{padding:16px 16px 0;flex-shrink:0}
.menu-sheet-body{overflow-y:auto;flex:1;padding:0 16px calc(32px + env(safe-area-inset-bottom));-webkit-overflow-scrolling:touch}
.menu-handle{width:36px;height:4px;background:var(--b2);border-radius:2px;margin:0 auto 20px}
.menu-ttl{font-size:10px;color:var(--t3);letter-spacing:.18em;text-transform:uppercase;margin-bottom:14px;padding:0 6px}
.mitem{display:flex;align-items:center;gap:14px;padding:14px 12px;border-radius:14px;cursor:pointer;margin-bottom:2px}
.mitem:active{background:var(--bg-card2)}
.mitem-ico{width:42px;height:42px;border-radius:12px;background:var(--bg-card);border:1px solid var(--b2);display:flex;align-items:center;justify-content:center;font-size:18px;flex-shrink:0}
.mitem-lbl{font-size:15px;color:var(--t1)}
.mitem-desc{font-size:11px;color:var(--t3);margin-top:2px}
.msep{height:1px;background:var(--b2);margin:8px 12px}

/* SORT SHEET */
.sort-sheet{position:fixed;bottom:0;left:50%;transform:translateX(-50%);width:100%;max-width:480px;background:var(--bg-sheet);border-top:1px solid var(--b1);border-radius:24px 24px 0 0;padding:20px 16px calc(32px + env(safe-area-inset-bottom));z-index:401;display:none}
.sort-sheet.show{display:block}
.sort-item{display:flex;align-items:center;justify-content:space-between;padding:14px 12px;border-radius:14px;cursor:pointer;font-size:14px;color:var(--t1)}
.sort-item:active{background:var(--bg-card2)}
.sort-item.on{color:var(--gold)}

/* MODAL */
.modal-bg{position:fixed;inset:0;background:rgba(0,0,0,.8);z-index:500;display:none;align-items:center;justify-content:center;padding:24px}
.modal-bg.show{display:flex}
.modal{background:var(--bg-sheet);border:1px solid var(--b1);border-radius:20px;padding:24px;width:100%;max-width:360px;box-shadow:0 24px 60px rgba(0,0,0,.8)}
.modal-title{font-family:'Cormorant Garamond',serif;font-size:22px;font-weight:300;color:var(--t1);margin-bottom:8px}
.modal-desc{font-size:13px;color:var(--t2);margin-bottom:18px;line-height:1.6}
.modal textarea{width:100%;background:var(--bg-input);border:1px solid var(--b2);border-radius:12px;padding:12px;color:var(--t2);font-size:11px;font-family:monospace;outline:none;resize:none;height:120px;margin-bottom:16px;display:block;line-height:1.5}
.share-link{background:var(--bg-input);border:1px solid var(--b2);border-radius:12px;padding:12px 14px;font-size:11px;color:var(--gold);word-break:break-all;line-height:1.5;margin-bottom:16px;cursor:pointer;font-family:monospace}

/* LOADING */
.loading{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100vh;gap:16px}
.ob-modal{position:fixed;inset:0;background:var(--bg);z-index:999;display:none;flex-direction:column;align-items:center;justify-content:center;padding:40px 28px;max-width:480px;margin:0 auto;overflow-y:auto}
.ob-modal.show{display:flex!important}
.ob-modal.show{display:flex}
.ob-dot{width:8px;height:8px;border-radius:50%;background:var(--b2);transition:all .3s;display:inline-block}
.ob-dot.on{background:var(--gold);width:24px;border-radius:4px}

.loading-spinner{width:32px;height:32px;border:2px solid var(--b2);border-top-color:var(--gold);border-radius:50%;animation:spin .8s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}
.loading-txt{font-size:13px;color:var(--t3);letter-spacing:.1em}

/* TOAST */
#toast{position:fixed;bottom:calc(90px + env(safe-area-inset-bottom));left:50%;transform:translateX(-50%);padding:11px 24px;border-radius:24px;font-size:13px;font-weight:400;z-index:600;white-space:nowrap;box-shadow:0 8px 30px rgba(0,0,0,.6);font-family:'DM Sans',sans-serif;display:none;pointer-events:none}
