*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{
  --bg:#0c0c0c;--sf:#141414;--sf2:#1a1a1a;--sf3:#222;
  --bd:#2a2a2a;--bd2:#333;
  --tx:#e8e8e8;--tx2:#888;--tx3:#444;
  --gn:#2d6a2d;--gl:#3a8a3a;--gd:rgba(45,106,45,0.15);
  --ac:#c8f0c8;--wh:#ffffff;
  --r:4px;--rl:6px;
  --amber:#c8a84b;--amberd:rgba(200,168,75,0.12);
  --blue:#4a7fc8;--blued:rgba(74,127,200,0.15);
}
body{font-family:'DM Sans',sans-serif;background:var(--bg);color:var(--tx);height:100vh;display:flex;flex-direction:column;overflow:hidden}
::-webkit-scrollbar{width:4px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--bd2);border-radius:2px}

/* NAV */
.topnav{background:var(--sf);border-bottom:1px solid var(--bd);padding:0 24px;height:52px;min-height:52px;display:flex;align-items:center;justify-content:space-between;z-index:200;flex-shrink:0}
.nav-logo{font-family:'Syne',sans-serif;font-size:17px;font-weight:700;letter-spacing:0.04em;color:var(--wh);display:flex;align-items:center;gap:9px}
.logo-dot{width:7px;height:7px;border-radius:50%;background:var(--gl);box-shadow:0 0 7px rgba(58,138,58,0.5)}
.nav-logo span{color:var(--gl)}
.nav-pill{font-size:9px;font-weight:500;letter-spacing:0.14em;text-transform:uppercase;padding:3px 9px;border-radius:2px;background:var(--gd);color:var(--ac);border:1px solid rgba(58,138,58,0.3)}
.nav-user{font-size:12px;color:var(--tx2)}
.nav-right{display:flex;align-items:center;gap:14px}

/* LAYOUT */
.app-body{display:grid;grid-template-columns:200px 1fr;flex:1;min-height:0;height:calc(100vh - 52px);overflow:hidden}
.content-area{display:grid;grid-template-columns:1fr 320px;min-height:0;overflow:hidden;height:100%}
.pages-wrapper{min-height:0;overflow:hidden;height:100%;position:relative}
.page{display:none;height:100%;overflow-y:auto}
.page.active{display:block}

/* SIDEBAR */
.sidebar{background:var(--sf);border-right:1px solid var(--bd);padding:18px 0;overflow-y:auto;height:100%}
.sb-section{padding:0 12px;margin-bottom:22px}
.sb-label{font-size:9px;font-weight:500;letter-spacing:0.18em;text-transform:uppercase;color:var(--tx3);padding:0 4px;margin-bottom:7px}
.partner-list{display:flex;flex-direction:column;gap:2px}
.pi{display:flex;align-items:center;justify-content:space-between;padding:7px 9px;border-radius:var(--r);cursor:pointer;transition:background 0.15s;border:1px solid transparent}
.pi:hover{background:var(--sf2)}
.pi.active{background:var(--sf3);border-color:var(--bd2)}
.pi-left{display:flex;align-items:center;gap:8px}
.pi-av{width:26px;height:26px;border-radius:3px;display:flex;align-items:center;justify-content:center;font-family:'Syne',sans-serif;font-size:9px;font-weight:700;flex-shrink:0;background:var(--gd);color:var(--ac);border:1px solid rgba(58,138,58,0.2)}
.pi-name{font-size:12px;color:var(--tx)}
.pi-dot{width:5px;height:5px;border-radius:50%;background:var(--gl);flex-shrink:0}
.pi-dot.off{background:var(--tx3)}
.sb-btn{width:100%;padding:7px 9px;background:none;border:1px dashed var(--bd2);border-radius:var(--r);color:var(--tx3);font-family:'DM Sans',sans-serif;font-size:11px;cursor:pointer;transition:all 0.15s;display:flex;align-items:center;gap:5px;margin-top:5px}
.sb-btn:hover{border-color:var(--tx2);color:var(--tx2)}
.sb-nav-item{padding:7px 13px;font-size:12px;color:var(--tx2);border-radius:var(--r);cursor:pointer;transition:all 0.15s;margin:1px 0;display:flex;align-items:center;gap:8px}
.sb-nav-item:hover{background:var(--sf2);color:var(--tx)}
.sb-nav-item.active-page{background:var(--sf3);color:var(--wh);border:1px solid var(--bd2)}
.sb-nav-dot{width:5px;height:5px;border-radius:50%;background:var(--tx3);flex-shrink:0}
.sb-nav-item.active-page .sb-nav-dot{background:var(--gl)}

/* MAIN PANEL */
.main-panel{padding:22px;display:flex;flex-direction:column;gap:18px}
.panel-header{display:flex;align-items:flex-start;justify-content:space-between;gap:14px}
.panel-title{font-family:'Syne',sans-serif;font-size:19px;font-weight:600;color:var(--wh);margin-bottom:3px}
.panel-sub{font-size:12px;color:var(--tx2)}
.hdr-actions{display:flex;gap:8px;flex-shrink:0}

/* STATS */
.stats-strip{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--bd);border:1px solid var(--bd);border-radius:var(--r);overflow:hidden}
.stat-cell{background:var(--sf);padding:12px 15px}
.stat-lbl{font-size:9px;font-weight:500;letter-spacing:0.14em;text-transform:uppercase;color:var(--tx3);margin-bottom:4px}
.stat-val{font-family:'Syne',sans-serif;font-size:19px;font-weight:600;color:var(--wh)}
.stat-val.green{color:var(--ac)}

/* CARD */
.card{background:var(--sf);border:1px solid var(--bd);border-radius:var(--rl);overflow:visible}
.card-hdr{padding:13px 18px;border-bottom:1px solid var(--bd);display:flex;align-items:center;justify-content:space-between;border-radius:var(--rl) var(--rl) 0 0}
.card-title{font-family:'Syne',sans-serif;font-size:12px;font-weight:600;color:var(--wh);letter-spacing:0.03em}
.card-hint{font-size:11px;color:var(--tx2)}
.card-body{padding:16px 18px}

/* FORM */
.fg{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.ff{display:flex;flex-direction:column;gap:5px}
.ff.full{grid-column:1/-1}
.fl{font-size:10px;font-weight:500;letter-spacing:0.12em;text-transform:uppercase;color:var(--tx2);display:flex;align-items:center;gap:5px}
.fo{font-size:9px;font-weight:400;letter-spacing:0.04em;color:var(--tx3);text-transform:none}
input[type=text],input[type=url],textarea,select{background:var(--sf2);border:1px solid var(--bd2);border-radius:var(--r);color:var(--tx);font-family:'DM Sans',sans-serif;font-size:12px;padding:8px 10px;width:100%;transition:border-color 0.15s;outline:none;appearance:none}
input:focus,textarea:focus,select:focus{border-color:var(--gl)}
input::placeholder,textarea::placeholder{color:var(--tx3)}
textarea{resize:vertical;min-height:64px;line-height:1.5}
select{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='11' height='11' viewBox='0 0 11 11'%3E%3Cpath d='M2.5 4l3 3 3-3' stroke='%23666' stroke-width='1.1' fill='none' stroke-linecap='round'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 9px center;padding-right:26px;cursor:pointer}
select option{background:var(--sf2)}

/* TOGGLE */
.trow{display:flex;align-items:center;justify-content:space-between;padding:8px 0;border-bottom:1px solid var(--bd)}
.trow:last-child{border-bottom:none;padding-bottom:0}
.trow:first-child{padding-top:0}
.tlbl{font-size:12px;color:var(--tx)}
.tdesc{font-size:11px;color:var(--tx2);margin-top:1px}
.tgl{position:relative;width:34px;height:19px;flex-shrink:0}
.tgl input{opacity:0;width:0;height:0}
.tgl-sl{position:absolute;inset:0;background:var(--sf3);border:1px solid var(--bd2);border-radius:10px;cursor:pointer;transition:background 0.2s,border-color 0.2s}
.tgl-sl::before{content:'';position:absolute;width:13px;height:13px;left:2px;top:50%;transform:translateY(-50%);background:var(--tx3);border-radius:50%;transition:transform 0.2s,background 0.2s}
.tgl input:checked+.tgl-sl{background:var(--gn);border-color:var(--gl)}
.tgl input:checked+.tgl-sl::before{transform:translateX(15px) translateY(-50%);background:var(--wh)}

/* OFFER TABS */
.offer-nav{display:flex;border-bottom:1px solid var(--bd);margin:-16px -18px 16px;overflow-x:auto}
.otab{font-family:'DM Sans',sans-serif;font-size:11px;padding:9px 14px;border:none;background:none;color:var(--tx3);cursor:pointer;border-bottom:2px solid transparent;margin-bottom:-1px;white-space:nowrap;transition:color 0.15s,border-color 0.15s;display:flex;align-items:center;gap:5px}
.otab:hover{color:var(--tx2)}
.otab.active{color:var(--wh);border-bottom-color:var(--gl)}
.otab-dot{width:5px;height:5px;border-radius:50%;background:var(--tx3);flex-shrink:0}
.otab.filled .otab-dot{background:var(--gl)}
.otab.linked-offer .otab-dot{background:var(--amber)}
.offer-panel{display:none;flex-direction:column;gap:12px}
.offer-panel.active{display:flex}

/* PRICE OPTIONAL */
.pgrid{display:grid;grid-template-columns:1fr 1fr 1fr;gap:9px;align-items:start}
.opt-f{display:flex;flex-direction:column;gap:0}
.opt-tr{display:flex;align-items:center;gap:5px;margin-bottom:5px;cursor:pointer}
.opt-tr input[type=checkbox]{width:12px;height:12px;accent-color:var(--gl);cursor:pointer;padding:0;flex-shrink:0}
.opt-lbl{font-size:10px;font-weight:500;letter-spacing:0.12em;text-transform:uppercase;color:var(--tx2);cursor:pointer}
.opt-lbl.dim{color:var(--tx3)}
.opt-f.disabled input[type=text]{opacity:0.3;pointer-events:none}

/* LINKED OFFER */
.linked-banner{background:rgba(200,168,75,0.1);border:1px solid rgba(200,168,75,0.3);border-radius:var(--r);padding:10px 13px;display:flex;align-items:center;justify-content:space-between;gap:10px}
.linked-banner-left{display:flex;align-items:center;gap:9px}
.linked-icon{font-size:14px}
.linked-info{font-size:11px;color:var(--amber);line-height:1.4}
.linked-info strong{font-weight:500;display:block;margin-bottom:1px}
.linked-info span{color:rgba(200,168,75,0.6);font-size:10px}
.btn-unlink{font-family:'DM Sans',sans-serif;font-size:10px;font-weight:500;letter-spacing:0.08em;padding:5px 10px;border-radius:var(--r);border:1px solid rgba(200,168,75,0.4);background:none;color:var(--amber);cursor:pointer;transition:all 0.15s}
.btn-unlink:hover{background:var(--amberd)}
.linked-fields{opacity:0.55;pointer-events:none;margin-top:4px}
.linked-field-note{font-size:10px;color:var(--tx3);margin-top:2px;font-style:italic}
.linked-edit-link{color:var(--amber);cursor:pointer;font-style:normal}
.linked-edit-link:hover{text-decoration:underline}

/* AFFILIATE ID */
.affid-row{background:var(--sf2);border:1px solid var(--bd2);border-radius:var(--r);padding:11px 13px;display:flex;flex-direction:column;gap:8px}
.affid-lbl{font-size:10px;font-weight:500;letter-spacing:0.12em;text-transform:uppercase;color:var(--tx2)}
.affid-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px}
.affid-item{display:flex;flex-direction:column;gap:4px}
.affid-item-lbl{font-size:9px;color:var(--tx3);letter-spacing:0.06em}
.affid-hint{font-size:10px;color:var(--tx3);line-height:1.5}
.affid-hint code{font-family:'Courier New',monospace;color:var(--amber);font-size:10px;background:var(--amberd);padding:1px 4px;border-radius:2px}
.affid-preview{font-size:10px;font-family:'Courier New',monospace;color:var(--ac);background:var(--bg);border:1px solid var(--bd);border-radius:2px;padding:4px 7px;margin-top:2px;word-break:break-all}

/* BUTTONS */
.btn{font-family:'DM Sans',sans-serif;font-size:11px;font-weight:500;letter-spacing:0.09em;text-transform:uppercase;padding:7px 15px;border-radius:var(--r);border:none;cursor:pointer;transition:all 0.15s;display:inline-flex;align-items:center;gap:6px;white-space:nowrap}
.btn-primary{background:var(--gn);color:var(--wh);border:1px solid var(--gl)}
.btn-primary:hover{background:var(--gl)}
.btn-secondary{background:var(--sf2);color:var(--tx2);border:1px solid var(--bd2)}
.btn-secondary:hover{color:var(--tx);border-color:var(--tx3)}
.btn-ghost{background:none;color:var(--tx3);border:1px solid transparent;padding:5px 9px}
.btn-ghost:hover{color:var(--tx2);border-color:var(--bd2)}
.btn-amber{background:var(--amberd);color:var(--amber);border:1px solid rgba(200,168,75,0.3)}
.btn-amber:hover{background:rgba(200,168,75,0.22)}
.btn-sm{padding:5px 11px;font-size:10px}

/* SNIPPET */
.snippet-box{background:var(--bg);border:1px solid var(--bd2);border-radius:var(--r);padding:11px 70px 11px 13px;font-family:'Courier New',monospace;font-size:11px;color:var(--ac);line-height:1.6;word-break:break-all;position:relative}
.snippet-copy{position:absolute;top:7px;right:7px;background:var(--sf2);border:1px solid var(--bd2);border-radius:var(--r);color:var(--tx2);font-family:'DM Sans',sans-serif;font-size:9px;letter-spacing:0.07em;padding:3px 9px;cursor:pointer;transition:all 0.15s}
.snippet-copy:hover{color:var(--wh);border-color:var(--tx2)}
.snippet-copy.ok{color:var(--ac);border-color:rgba(58,138,58,0.4)}
.info-row{display:flex;align-items:center;justify-content:space-between;padding:6px 0;border-bottom:1px solid var(--bd)}
.info-row:last-child{border-bottom:none}
.info-key{font-size:11px;color:var(--tx2)}
.info-val{font-size:11px;color:var(--tx);font-weight:500}
.tag{display:inline-flex;align-items:center;font-size:9px;font-weight:500;letter-spacing:0.1em;text-transform:uppercase;padding:3px 7px;border-radius:2px}
.tag-green{background:var(--gd);color:var(--ac);border:1px solid rgba(58,138,58,0.25)}
.tag-gray{background:var(--sf3);color:var(--tx3);border:1px solid var(--bd)}

/* PREVIEW PANEL */
.preview-panel{border-left:1px solid var(--bd);background:#0a120a;display:flex;flex-direction:column;overflow:hidden;height:100%}
.pv-header{padding:12px 16px;border-bottom:1px solid var(--bd);display:flex;align-items:center;justify-content:space-between;background:var(--sf);flex-shrink:0}
.pv-title{font-family:'Syne',sans-serif;font-size:10px;font-weight:600;letter-spacing:0.16em;text-transform:uppercase;color:var(--tx2)}
.theme-pips{display:flex;gap:4px}
.tpip{width:18px;height:18px;border-radius:3px;border:1px solid var(--bd2);cursor:pointer;transition:border-color 0.15s}
.tpip:hover{border-color:var(--tx2)}
.tpip.active{border-color:var(--gl)}
.pip-clean{background:#f0ede6}
.pip-frost{background:linear-gradient(135deg,#1a3a2a,#0d1f18)}
.pip-dark{background:#0e0e0e}
.pv-scene{flex:1;overflow:hidden;position:relative;display:flex;align-items:flex-end;justify-content:center;transition:background 0.4s}
.mini-page{position:absolute;top:16px;left:9px;right:9px;background:#fff;border-radius:4px;padding:12px;opacity:0.5}
.mini-bar{height:6px;background:#e8e4dc;border-radius:2px;margin-bottom:8px;width:55%}
.mini-lines{display:flex;flex-direction:column;gap:4px}
.mini-line{height:5px;background:#f0ede6;border-radius:2px}
.ml-l{width:90%}.ml-m{width:65%}.ml-s{width:40%}

/* LIVE WIDGET */
.lw{position:relative;z-index:2;width:100%;border-radius:5px 5px 0 0;overflow:hidden;transition:all 0.3s}
.lw.t-clean{background:#fff;border:1px solid #e8e4dc;border-bottom:none;box-shadow:0 -4px 22px rgba(0,0,0,0.12)}
.lw.t-frost{background:rgba(255,255,255,0.15);backdrop-filter:blur(20px);border:1px solid rgba(255,255,255,0.28);border-bottom:none;box-shadow:0 -4px 26px rgba(0,0,0,0.28)}
.lw.t-dark{background:#161616;border:1px solid #2a2a2a;border-bottom:none;box-shadow:0 -4px 30px rgba(0,0,0,0.7)}
.wbar{padding:6px 12px;display:flex;align-items:center;justify-content:space-between}
.t-clean .wbar{background:#141414}.t-frost .wbar{background:rgba(0,0,0,0.22)}.t-dark .wbar{background:#0e0e0e}
.wlbl{font-size:8px;letter-spacing:0.18em;text-transform:uppercase;font-family:'DM Sans',sans-serif;color:rgba(255,255,255,0.4)}
.t-dark .wlbl{color:#3a3a3a}
.wdots{display:flex;gap:4px;align-items:center}
.wdot{width:5px;height:5px;border-radius:50%}
.t-clean .wdot,.t-frost .wdot{background:rgba(255,255,255,0.18)}.t-dark .wdot{background:#2a2a2a}
.t-clean .wdot.on{background:#fff}.t-frost .wdot.on{background:rgba(255,255,255,0.85)}.t-dark .wdot.on{background:#e0e0e0}
.wcnt{font-size:8px;letter-spacing:0.08em;font-family:'DM Sans',sans-serif}
.t-clean .wcnt,.t-frost .wcnt{color:rgba(255,255,255,0.25)}.t-dark .wcnt{color:#2e2e2e}
.wbody{display:grid;grid-template-columns:72px 1fr}
.wimg{display:flex;align-items:center;justify-content:center;padding:11px 9px;position:relative;min-height:92px}
.t-clean .wimg{background:#f7f6f2;border-right:1px solid #eee}
.t-frost .wimg{background:rgba(255,255,255,0.07);border-right:1px solid rgba(255,255,255,0.1)}
.t-dark .wimg{background:#111;border-right:1px solid #1e1e1e}
.wbadge{position:absolute;top:5px;left:5px;font-size:7px;font-weight:500;letter-spacing:0.08em;text-transform:uppercase;padding:2px 5px;border-radius:2px;font-family:'DM Sans',sans-serif}
.t-clean .wbadge{background:#2a5f2a;color:#fff}
.t-frost .wbadge{background:rgba(42,95,42,0.5);color:#b8ecb8}
.t-dark .wbadge{background:#1a301a;color:#5aaa5a}
.wcontent{padding:10px 12px;display:flex;flex-direction:column;gap:4px}
.wey{font-size:8px;font-weight:500;letter-spacing:0.12em;text-transform:uppercase;font-family:'DM Sans',sans-serif}
.t-clean .wey{color:#2a5f2a}.t-frost .wey{color:#4aaa4a}.t-dark .wey{color:#5aaa5a}
.wti{line-height:1.15}
.t-clean .wti{font-family:'Cormorant Garamond',serif;font-size:13px;font-weight:600;color:#1a1a1a}
.t-frost .wti{font-family:'Cormorant Garamond',serif;font-size:13px;font-weight:600;color:rgba(20,20,20,0.92)}
.t-dark .wti{font-family:'Inter',sans-serif;font-size:11px;font-weight:500;color:#e8e8e8;letter-spacing:-0.01em}
.wde{font-size:9px;line-height:1.45;font-family:'DM Sans',sans-serif}
.t-clean .wde{color:#888}.t-frost .wde{color:rgba(20,20,20,0.5)}.t-dark .wde{color:#555}
.wpr-row{display:flex;align-items:baseline;gap:4px;margin-top:1px;flex-wrap:wrap}
.wpr{font-size:13px;font-weight:500;letter-spacing:-0.01em}
.t-clean .wpr,.t-frost .wpr{color:#1a1a1a}.t-dark .wpr{color:#e8e8e8}
.wwa{font-size:9px;text-decoration:line-through;font-family:'DM Sans',sans-serif}
.t-clean .wwa{color:#ccc}.t-frost .wwa{color:rgba(20,20,20,0.28)}.t-dark .wwa{color:#333}
.wsa{font-size:8px;font-weight:500;font-family:'DM Sans',sans-serif}
.t-clean .wsa{color:#2a5f2a}.t-frost .wsa{color:#2a7a2a}.t-dark .wsa{color:#5aaa5a}
.wactions{display:grid;grid-template-columns:1fr 1fr}
.t-clean .wactions{border-top:1px solid #eee}
.t-frost .wactions{border-top:1px solid rgba(0,0,0,0.07)}
.t-dark .wactions{border-top:1px solid #1e1e1e}
.wacc{font-size:9px;font-weight:500;letter-spacing:0.09em;text-transform:uppercase;padding:9px 7px;border:none;display:flex;align-items:center;justify-content:center;gap:4px;font-family:'DM Sans',sans-serif;cursor:default}
.t-clean .wacc{background:#141414;color:#fff}
.t-frost .wacc{background:rgba(20,20,20,0.72);color:#fff}
.t-dark .wacc{background:#e8e8e8;color:#111}
.wdec{font-size:9px;letter-spacing:0.03em;padding:9px 7px;border:none;text-align:center;font-family:'DM Sans',sans-serif;cursor:default}
.t-clean .wdec{background:#fff;color:#aaa;border-left:1px solid #eee}
.t-frost .wdec{background:rgba(255,255,255,0.22);color:#666;border-left:1px solid rgba(0,0,0,0.06)}
.t-dark .wdec{background:#161616;color:#3a3a3a;border-left:1px solid #1e1e1e}
.wfoot{padding:5px 12px;text-align:center}
.t-clean .wfoot{border-top:1px solid #f4f2ee}
.t-frost .wfoot{border-top:1px solid rgba(0,0,0,0.05)}
.t-dark .wfoot{border-top:1px solid #1a1a1a}
.wpow{font-size:8px;letter-spacing:0.05em;font-family:'DM Sans',sans-serif}
.t-clean .wpow{color:#ccc}.t-frost .wpow{color:rgba(20,20,20,0.3)}.t-dark .wpow{color:#2a2a2a}

/* LIBRARY PAGE */
.lib-page{padding:22px;display:flex;flex-direction:column;gap:18px}
.lib-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:4px}
.lib-title{font-family:'Syne',sans-serif;font-size:19px;font-weight:600;color:var(--wh)}
.lib-sub{font-size:12px;color:var(--tx2);margin-top:3px}
.adv-section{display:flex;flex-direction:column;gap:10px}
.adv-hdr{display:flex;align-items:center;justify-content:space-between;padding:10px 14px;background:var(--sf);border:1px solid var(--bd);border-radius:var(--r);cursor:pointer}
.adv-hdr:hover{border-color:var(--bd2)}
.adv-left{display:flex;align-items:center;gap:10px}
.adv-pill{font-size:9px;font-weight:500;letter-spacing:0.12em;text-transform:uppercase;padding:3px 8px;border-radius:2px}
.adv-pg{background:var(--gd);color:var(--ac);border:1px solid rgba(58,138,58,0.3)}
.adv-np{background:var(--blued);color:#8ab4f8;border:1px solid rgba(74,127,200,0.3)}
.adv-name{font-family:'Syne',sans-serif;font-size:13px;font-weight:600;color:var(--wh)}
.adv-count{font-size:11px;color:var(--tx3)}
.adv-chev{color:var(--tx3);transition:transform 0.2s;font-size:11px}
.adv-section.open .adv-chev{transform:rotate(180deg)}
.lib-grid{display:none;grid-template-columns:1fr 1fr;gap:10px}
.adv-section.open .lib-grid{display:grid}
.loc{background:var(--sf);border:1px solid var(--bd);border-radius:var(--r);overflow:hidden}
.loc:hover{border-color:var(--bd2)}
.loc-hdr{padding:10px 13px;border-bottom:1px solid var(--bd);display:flex;align-items:flex-start;justify-content:space-between;gap:8px}
.loc-title{font-size:12px;font-weight:500;color:var(--wh);line-height:1.3;flex:1}
.loc-badge{font-size:8px;font-weight:500;letter-spacing:0.08em;text-transform:uppercase;padding:2px 6px;border-radius:2px;background:var(--sf3);color:var(--tx3);flex-shrink:0;white-space:nowrap}
.loc-body{padding:10px 13px;display:flex;flex-direction:column;gap:5px}
.loc-desc{font-size:11px;color:var(--tx2);line-height:1.45}
.loc-pr-row{display:flex;align-items:baseline;gap:5px}
.loc-price{font-size:14px;font-weight:500;color:var(--wh)}
.loc-was{font-size:10px;color:var(--tx3);text-decoration:line-through}
.loc-save{font-size:9px;color:var(--ac)}
.loc-url{font-size:9px;font-family:'Courier New',monospace;color:var(--tx3);padding:4px 6px;background:var(--bg);border-radius:2px;word-break:break-all;margin-top:2px}
.loc-url .url-var{color:var(--amber)}
.loc-footer{padding:7px 13px;border-top:1px solid var(--bd);display:flex;align-items:center;justify-content:space-between;gap:6px}
.loc-partners{font-size:10px;color:var(--tx3)}
.loc-add{background:var(--sf);border:1px dashed var(--bd2);border-radius:var(--r);display:flex;align-items:center;justify-content:center;padding:24px;cursor:pointer;transition:border-color 0.2s;min-height:100px}
.loc-add:hover{border-color:var(--tx2)}
.loc-add-inner{display:flex;flex-direction:column;align-items:center;gap:5px;color:var(--tx3)}
.loc-add-icon{font-size:18px}
.loc-add-label{font-size:11px}

/* LIBRARY SLIDE-IN */
.lib-panel-ov{position:fixed;inset:0;background:rgba(0,0,0,0.5);z-index:300;display:none;align-items:flex-end;justify-content:flex-end}
.lib-panel-ov.open{display:flex}
.lib-panel{background:var(--sf);border-left:1px solid var(--bd2);width:440px;height:100%;display:flex;flex-direction:column;overflow:hidden;animation:slideIn 0.28s cubic-bezier(0.22,1,0.36,1)}
@keyframes slideIn{from{transform:translateX(100%)}to{transform:translateX(0)}}
.lib-panel-hdr{padding:16px 20px;border-bottom:1px solid var(--bd);display:flex;align-items:center;justify-content:space-between;flex-shrink:0}
.lib-panel-title{font-family:'Syne',sans-serif;font-size:14px;font-weight:600;color:var(--wh)}
.lib-panel-sub{font-size:11px;color:var(--tx2);margin-top:2px}
.lib-panel-close{background:none;border:none;color:var(--tx3);font-size:18px;cursor:pointer;padding:2px 6px;transition:color 0.15s}
.lib-panel-close:hover{color:var(--tx)}
.lib-panel-body{flex:1;overflow-y:auto;padding:16px;display:flex;flex-direction:column;gap:16px}
.lib-panel-sec-lbl{font-size:9px;font-weight:500;letter-spacing:0.16em;text-transform:uppercase;color:var(--tx3);margin-bottom:7px;padding-bottom:5px;border-bottom:1px solid var(--bd)}
.lib-offer-row{display:flex;align-items:center;justify-content:space-between;padding:9px 11px;border:1px solid var(--bd);border-radius:var(--r);margin-bottom:6px;gap:10px}
.lib-offer-row:hover{border-color:var(--bd2)}
.lib-offer-row-left{flex:1;min-width:0}
.lib-offer-row-title{font-size:12px;color:var(--tx);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.lib-offer-row-price{font-size:10px;color:var(--tx2);margin-top:2px}
.lib-offer-row-actions{display:flex;gap:5px;flex-shrink:0}
.btn-link-offer{font-family:'DM Sans',sans-serif;font-size:10px;font-weight:500;letter-spacing:0.07em;padding:5px 10px;border-radius:var(--r);border:1px solid rgba(200,168,75,0.4);background:var(--amberd);color:var(--amber);cursor:pointer;transition:all 0.15s}
.btn-link-offer:hover{background:rgba(200,168,75,0.25)}
.btn-copy-offer{font-family:'DM Sans',sans-serif;font-size:10px;font-weight:500;letter-spacing:0.07em;padding:5px 10px;border-radius:var(--r);border:1px solid var(--bd2);background:var(--sf2);color:var(--tx2);cursor:pointer;transition:all 0.15s}
.btn-copy-offer:hover{color:var(--tx);border-color:var(--tx3)}
.lib-explainer{padding:11px 13px;background:var(--sf2);border:1px solid var(--bd);border-radius:var(--r);font-size:11px;color:var(--tx2);line-height:1.6}

/* PLACEHOLDER PAGES */
.placeholder-page{display:flex;align-items:center;justify-content:center;height:100%;flex-direction:column;gap:12px;color:var(--tx3)}

/* MODALS */
.modal-ov{position:fixed;inset:0;background:rgba(0,0,0,0.72);z-index:400;display:none;align-items:flex-start;justify-content:center;padding:40px 20px;overflow-y:auto}
.modal-ov.open{display:flex}
.modal{background:var(--sf);border:1px solid var(--bd2);border-radius:var(--rl);padding:24px;width:100%;max-width:480px;margin:auto}
.modal-wide{max-width:540px}
.modal-title{font-family:'Syne',sans-serif;font-size:15px;font-weight:600;color:var(--wh);margin-bottom:16px}
.modal-actions{display:flex;gap:7px;justify-content:flex-end;margin-top:16px;padding-top:14px;border-top:1px solid var(--bd)}
.modal-warn{background:rgba(200,168,75,0.1);border:1px solid rgba(200,168,75,0.3);border-radius:var(--r);padding:9px 13px;margin-bottom:14px;font-size:11px;color:var(--amber)}