
*{box-sizing:border-box;margin:0;padding:0;}
:root{
  --bg:#FFFFFF;--bg-sb:#F7F5F1;--bg-s:#FFFFFF;--bg-s2:#FAF8F4;--bg-warm:#F5EFE6;
  --tx:#1D1F2C;--tx2:#6B6762;--tx3:#B0ABA5;
  --navy:#1C1E29;--cream:#F9F7F2;--copper:#B37356;
  --copper-lt:rgba(179,115,86,0.1);--copper-bd:rgba(179,115,86,0.3);
  --bd:rgba(29,31,44,0.08);--bd2:rgba(29,31,44,0.15);
  --gr:#2A7A50;--gr-dim:rgba(42,122,80,0.1);
  --am:#A86820;--am-dim:rgba(168,104,32,0.1);
  --re:#9A2828;--re-dim:rgba(154,40,40,0.1);
  --bl:#1A50A0;--bl-dim:rgba(26,80,160,0.1);
  --rad:8px;--rad-sm:5px;
  --f:'Inter',system-ui,sans-serif;
}
*{font-family:var(--f);}
html,body{height:100%;margin:0;}
.app{display:flex;flex-direction:column;height:100vh;background:var(--bg);color:var(--tx);}
.hdr{height:48px;background:var(--navy);display:flex;align-items:center;padding:0 18px;gap:8px;flex-shrink:0;}
.hdr-name{font-size:13px;font-weight:600;color:var(--cream);letter-spacing:-0.02em;}
.hdr-sp{flex:1;}
.hdr-add{font-size:11px;font-weight:600;background:rgba(249,247,242,0.12);color:rgba(249,247,242,0.85);border:none;border-radius:var(--rad-sm);padding:5px 11px;cursor:pointer;opacity:0;transition:opacity 0.2s;outline:none;}
.hdr-add.vis{opacity:1;}
.body{display:flex;flex:1;overflow:hidden;}
.rail{width:58px;flex-shrink:0;background:var(--navy);display:flex;flex-direction:column;align-items:center;padding:10px 0;border-right:1px solid rgba(249,247,242,0.06);}
.rail-nav{display:flex;flex-direction:column;align-items:center;gap:2px;flex:1;}
.ri{width:44px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;padding:8px 0;cursor:pointer;user-select:none;color:rgba(249,247,242,0.38);transition:color 0.15s;}
.ri:hover{color:rgba(249,247,242,0.65);}
.ri.active{color:var(--copper);}
.ri svg{width:18px;height:18px;display:block;}
.ri-lbl{font-size:8px;font-weight:600;letter-spacing:0.07em;text-transform:uppercase;}
.rail-bot{flex-shrink:0;padding-top:8px;border-top:1px solid rgba(249,247,242,0.08);display:flex;justify-content:center;}
.av-btn{width:32px;height:32px;border-radius:50%;background:var(--copper);display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:700;color:var(--cream);cursor:pointer;border:none;outline:none;user-select:none;transition:opacity 0.15s;}
.av-btn:hover{opacity:0.85;}
.sp{position:absolute;bottom:calc(100% + 8px);left:calc(100% + 8px);background:#fff;border:1px solid rgba(29,31,44,0.1);border-radius:var(--rad);padding:4px;min-width:172px;box-shadow:0 4px 20px rgba(29,31,44,0.1);z-index:200;animation:pu 0.13s ease;}
@keyframes pu{from{opacity:0;transform:translateY(4px)}to{opacity:1;transform:none}}
.sp.hidden{display:none;}
.sp-hdr{padding:9px 10px 8px;border-bottom:1px solid rgba(29,31,44,0.07);margin-bottom:3px;}
.sp-hdr-name{font-size:11px;font-weight:600;color:var(--tx);}
.sp-hdr-url{font-size:10px;color:var(--tx3);}
.sp-row{display:flex;align-items:center;gap:9px;padding:7px 10px;font-size:12px;font-weight:500;color:var(--tx2);cursor:pointer;border-radius:4px;transition:color 0.1s,background 0.1s;user-select:none;}
.sp-row:hover{color:var(--tx);background:rgba(29,31,44,0.05);}
.sp-row svg{width:13px;height:13px;flex-shrink:0;opacity:0.4;}
.sp-row:hover svg{opacity:0.7;}
.sp-div{height:1px;background:rgba(29,31,44,0.07);margin:3px 2px;}
.panel{display:flex;flex:1;overflow:hidden;}
.sb{width:200px;flex-shrink:0;background:var(--bg-sb);border-right:1px solid var(--bd);display:flex;flex-direction:column;}
.sb-scr{flex:1;overflow-y:auto;padding:10px 8px;}
.sb-empty{padding:12px 10px;font-size:12px;color:var(--tx3);line-height:1.5;}
.sb-cat{font-size:9px;font-weight:600;text-transform:uppercase;letter-spacing:0.08em;color:var(--tx3);padding:10px 8px 4px;}
.sb-cat:first-child{padding-top:4px;}
.sb-item{display:flex;align-items:center;gap:8px;padding:5px 8px;border-radius:var(--rad);cursor:pointer;font-size:12px;font-weight:500;color:var(--tx2);transition:background 0.1s,color 0.1s;}
.sb-item:hover{background:rgba(29,31,44,0.06);color:var(--tx);}
.sb-item.active{color:var(--tx);background:rgba(29,31,44,0.05);}
.sb-add-offer{display:flex;align-items:center;gap:6px;padding:7px 8px;margin-top:4px;font-size:11px;font-weight:600;color:var(--copper);cursor:pointer;border-radius:var(--rad);transition:background 0.1s;}
.sb-add-offer:hover{background:rgba(186,117,23,0.08);}
.dot{width:6px;height:6px;border-radius:50%;flex-shrink:0;}
.dot.on{background:var(--gr);}
.dot.off{background:transparent;border:1.5px solid #D0CCC6;}
.main{flex:1;overflow-y:auto;}
.es{padding:40px 32px;max-width:440px;}
.es-name{font-size:28px;font-weight:700;color:var(--tx);margin-bottom:3px;letter-spacing:-0.03em;line-height:1.15;}
.es-url{font-size:11px;color:var(--tx3);margin-bottom:16px;}
.es-voice{font-size:13px;color:var(--tx);line-height:1.65;margin-bottom:20px;}
.es-hint{font-size:12px;color:var(--tx3);line-height:1.5;}
@keyframes fu{from{opacity:0;transform:translateY(5px)}to{opacity:1;transform:none}}
.ap{padding:22px 26px;animation:fu 0.2s ease both;}
.ap-crumb{font-size:11px;color:var(--tx3);margin-bottom:6px;}
.ap-title{font-size:18px;font-weight:700;color:var(--tx);letter-spacing:-0.03em;margin-bottom:18px;}
.ap-lbl{font-size:9px;font-weight:600;text-transform:uppercase;letter-spacing:0.08em;color:var(--tx3);margin-bottom:10px;}
.ap-row{display:flex;align-items:flex-start;gap:10px;padding:10px 0;border-bottom:1px solid var(--bd);cursor:pointer;transition:opacity 0.12s;}
.ap-row:last-of-type{border-bottom:none;}
.ap-row:hover{opacity:0.65;}
.ap-dot{width:7px;height:7px;border-radius:50%;flex-shrink:0;margin-top:3px;}
.ap-dot.built{background:var(--gr);}
.ap-dot.empty{background:transparent;border:1.5px solid #D0CCC6;}
.ap-dot.pend{background:var(--copper);animation:pulse 1s infinite;}
.ap-name{font-size:12px;font-weight:600;color:var(--tx);margin-bottom:2px;letter-spacing:-0.01em;}
.ap-desc{font-size:11px;color:var(--tx3);line-height:1.4;}
.ap-arr{font-size:11px;color:var(--tx3);margin-left:auto;padding-top:2px;flex-shrink:0;}
.ap-feat-sec{margin-top:14px;padding-top:14px;border-top:1px solid var(--bd);}
.ap-feat-row{display:flex;align-items:flex-start;gap:10px;padding:8px 0;border-bottom:1px dashed var(--bd);}
.ap-feat-row:last-of-type{border-bottom:none;}
.ap-feat-dot{width:7px;height:7px;border-radius:50%;flex-shrink:0;margin-top:3px;background:transparent;border:1px dashed #D0CCC6;}
.ap-feat-name{font-size:11px;font-weight:500;color:var(--tx3);}
.ap-feat-desc{font-size:10px;color:var(--tx3);line-height:1.4;opacity:0.7;}
.ws{padding:24px 28px;animation:fu 0.22s ease both;}
.ws-back{font-size:11px;color:var(--tx3);cursor:pointer;margin-bottom:10px;display:inline-flex;align-items:center;gap:4px;user-select:none;transition:color 0.1s;}
.ws-back:hover{color:var(--tx2);}
.ws-title{font-size:18px;font-weight:700;color:var(--tx);margin-bottom:4px;line-height:1.25;letter-spacing:-0.03em;}
.ws-desc{font-size:12px;color:var(--tx2);line-height:1.55;margin-bottom:16px;}
.ws-acts{display:flex;align-items:center;gap:14px;padding-bottom:16px;border-bottom:1px solid var(--bd);}
.ws-gen{font-size:11px;font-weight:600;letter-spacing:0.02em;text-transform:uppercase;color:var(--tx);cursor:pointer;user-select:none;transition:opacity 0.15s;border-bottom:1.5px solid var(--tx);padding-bottom:1px;}
.ws-gen:hover{opacity:0.5;}
.ws-gen.loading{opacity:0.4;cursor:default;color:var(--tx3);border-color:var(--tx3);}
.ws-exp{font-size:11px;font-weight:500;color:var(--tx3);cursor:pointer;user-select:none;}
.ws-feat{font-size:11px;color:var(--am);background:var(--am-dim);border:1px solid rgba(168,104,32,0.12);border-radius:var(--rad-sm);padding:9px 12px;margin-bottom:12px;line-height:1.55;}
.secs{padding-top:2px;}
.sec{border-bottom:1px solid var(--bd);}
.sec:last-child{border-bottom:none;}
.sec-hdr{display:flex;align-items:center;gap:10px;padding:11px 0;cursor:pointer;user-select:none;transition:opacity 0.1s;}
.sec-hdr:hover{opacity:0.65;}
.sec-dot{width:6px;height:6px;border-radius:50%;background:#D8D4CE;flex-shrink:0;transition:background 0.3s;}
.sec-dot.done{background:var(--gr);}
.sec-dot.loading{background:var(--copper);animation:pulse 1s infinite;}
.sec-lbl{font-size:12px;font-weight:500;color:var(--tx);flex:1;letter-spacing:-0.01em;}
.sec-st{font-size:11px;color:var(--tx3);}
.sec-chev{font-size:10px;color:var(--tx3);transition:transform 0.2s;}
.sec-chev.open{transform:rotate(180deg);}
.sec-body{max-height:0;overflow:hidden;transition:max-height 0.3s ease,padding 0.15s;}
.sec-body.open{max-height:3000px;padding:0 0 14px;}
.sec-empty{font-size:11px;color:var(--tx3);padding:2px 0 4px;}
.sec-act{display:inline-flex;font-size:10px;font-weight:600;letter-spacing:0.04em;text-transform:uppercase;color:var(--copper);cursor:pointer;user-select:none;transition:opacity 0.15s;border-bottom:1px solid var(--copper-bd);padding-bottom:1px;margin-bottom:10px;}
.sec-act:hover{opacity:0.6;}
.load-txt{font-size:11px;color:var(--tx3);padding:8px 0;}
.card{border-top:1px solid var(--bd);padding:10px 0;}
.card:first-child{border-top:none;}
.card-name{font-size:12px;font-weight:600;color:var(--tx);margin-bottom:2px;}
.tag{display:inline-block;font-size:9px;font-weight:600;padding:2px 6px;border-radius:20px;margin:2px 2px 2px 0;line-height:1.5;}
.tr{background:var(--re-dim);color:var(--re);}
.ta{background:var(--am-dim);color:var(--am);}
.tb{background:var(--bl-dim);color:var(--bl);}
.tg{background:rgba(29,31,44,0.07);color:var(--tx2);}
.sw{font-size:10px;font-weight:500;color:var(--am);background:var(--am-dim);border-radius:20px;padding:2px 6px;margin:2px 2px 2px 0;display:inline-block;line-height:1.4;}
.hl{border-left:2px solid var(--copper);padding:5px 9px;margin-bottom:5px;font-size:11px;line-height:1.5;color:var(--tx);background:var(--bg-warm);border-radius:0 var(--rad-sm) var(--rad-sm) 0;}
.jn{width:18px;height:18px;border-radius:50%;background:var(--bg-s2);border:1px solid var(--bd2);display:flex;align-items:center;justify-content:center;font-size:9px;font-weight:600;color:var(--tx3);flex-shrink:0;margin-top:1px;}
.ava{width:28px;height:28px;border-radius:50%;background:var(--copper-lt);display:flex;align-items:center;justify-content:center;font-size:10px;font-weight:700;color:var(--copper);flex-shrink:0;}
.plt-bar{display:flex;gap:4px;margin-bottom:9px;}
.plt-btn{font-size:11px;font-weight:500;padding:3px 9px;border-radius:20px;border:1px solid var(--bd2);background:transparent;color:var(--tx2);cursor:pointer;outline:none;}
.plt-btn.on{background:var(--tx);color:#fff;border-color:var(--tx);}
.sm{flex:1;overflow-y:auto;padding:28px 32px;}
.sm-title{font-size:9px;font-weight:600;text-transform:uppercase;letter-spacing:0.08em;color:var(--tx3);margin-bottom:16px;}
.tr-row{display:flex;align-items:flex-start;gap:12px;padding:13px 0;border-bottom:1px solid var(--bd);cursor:pointer;transition:opacity 0.12s;}
.tr-row:last-child{border-bottom:none;}
.tr-row:hover{opacity:0.65;}
.tr-ico{width:16px;height:16px;flex-shrink:0;margin-top:2px;color:var(--tx3);}
.tr-ico svg{width:16px;height:16px;display:block;}
.tr-name{font-size:12px;font-weight:600;color:var(--tx);letter-spacing:-0.01em;margin-bottom:2px;}
.tr-desc{font-size:11px;color:var(--tx3);line-height:1.45;}
.tr-arr{font-size:11px;color:var(--tx3);margin-left:auto;padding-top:2px;flex-shrink:0;}
.fl{width:200px;flex-shrink:0;background:var(--bg-sb);border-right:1px solid var(--bd);display:flex;flex-direction:column;overflow:hidden;}
.fl-hdr{padding:12px 12px 8px;border-bottom:1px solid var(--bd);display:flex;align-items:center;justify-content:space-between;}
.fl-hdr-t{font-size:9px;font-weight:600;text-transform:uppercase;letter-spacing:0.08em;color:var(--tx3);}
.fl-up{font-size:11px;font-weight:500;color:var(--copper);cursor:pointer;user-select:none;}
.fl-scr{flex:1;overflow-y:auto;padding:6px 8px;}
.fl-src{font-size:9px;font-weight:600;text-transform:uppercase;letter-spacing:0.08em;color:var(--tx3);padding:8px 6px 3px;}
.fl-item{display:flex;align-items:center;gap:6px;padding:5px 8px;border-radius:var(--rad);cursor:pointer;transition:background 0.1s;}
.fl-item:hover{background:rgba(29,31,44,0.05);}
.fl-item.active{background:rgba(29,31,44,0.07);}
.fl-dot{width:5px;height:5px;border-radius:50%;flex-shrink:0;}
.fl-dot.mapped{background:var(--gr);}
.fl-dot.partial{background:var(--am);}
.fl-dot.fresh{background:#D0CCC6;}
.fl-name{font-size:12px;font-weight:500;color:var(--tx2);flex:1;}
.fl-item.active .fl-name{color:var(--tx);}
.fl-date{font-size:10px;color:var(--tx3);}
.dm{flex:1;overflow-y:auto;}
.fd{padding:20px 24px;}
.fd-hdr{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:16px;padding-bottom:14px;border-bottom:1px solid var(--bd);}
.fd-badge{display:inline-block;font-size:9px;font-weight:600;padding:2px 7px;border-radius:20px;background:var(--bl-dim);color:var(--bl);margin-bottom:5px;letter-spacing:0.03em;}
.fd-badge.tiktok{background:var(--re-dim);color:var(--re);}
.fd-badge.budget{background:var(--gr-dim);color:var(--gr);}
.fd-fn{font-size:14px;font-weight:700;color:var(--tx);letter-spacing:-0.02em;margin-bottom:3px;}
.fd-rng{font-size:11px;color:var(--tx2);}
.fd-mw{position:relative;flex-shrink:0;}
.fd-mb{width:28px;height:28px;display:flex;align-items:center;justify-content:center;cursor:pointer;border-radius:var(--rad-sm);color:var(--tx3);font-size:16px;letter-spacing:1px;line-height:1;transition:background 0.1s;user-select:none;}
.fd-mb:hover,.fd-mb.open{background:rgba(29,31,44,0.06);color:var(--tx2);}
.fd-dd{position:absolute;top:calc(100% + 4px);right:0;background:#fff;border:1px solid rgba(29,31,44,0.1);border-radius:var(--rad);padding:4px;min-width:140px;box-shadow:0 4px 16px rgba(29,31,44,0.1);z-index:100;}
.fd-dd.hidden{display:none;}
.fd-ddi{display:flex;align-items:center;gap:8px;padding:7px 10px;font-size:12px;font-weight:500;color:var(--tx2);cursor:pointer;border-radius:4px;transition:color 0.1s,background 0.1s;user-select:none;}
.fd-ddi:hover{color:var(--tx);background:rgba(29,31,44,0.05);}
.fd-ddi.danger{color:var(--re);}
.fd-ddi.danger:hover{background:var(--re-dim);}
.fd-ddv{height:1px;background:rgba(29,31,44,0.07);margin:3px 2px;}
.fd-sec{margin-bottom:18px;}
.fd-sec-t{font-size:9px;font-weight:600;text-transform:uppercase;letter-spacing:0.08em;color:var(--tx3);margin-bottom:8px;}
.ptbl{width:100%;border-collapse:collapse;font-size:11px;}
.ptbl th{text-align:left;font-size:9px;font-weight:600;text-transform:uppercase;letter-spacing:0.06em;color:var(--tx3);padding:5px 9px;background:var(--bg-s2);border-bottom:1px solid var(--bd);}
.ptbl td{padding:5px 9px;border-bottom:1px solid var(--bd);color:var(--tx2);max-width:130px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;}
.ptbl tr:last-child td{border-bottom:none;}
.twrap{border:1px solid var(--bd);border-radius:var(--rad);overflow:hidden;}
.mr{display:flex;align-items:center;padding:8px 12px;border-bottom:1px solid var(--bd);gap:10px;}
.mr:last-child{border-bottom:none;}
.mr-dim{font-size:11px;font-weight:600;color:var(--tx);width:88px;flex-shrink:0;}
.mr-val{flex:1;font-size:11px;font-weight:500;color:var(--tx2);}
.mr-ex{font-size:10px;color:var(--tx3);flex:1;font-style:italic;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;}
.ba{font-size:9px;font-weight:600;padding:2px 6px;border-radius:20px;background:var(--gr-dim);color:var(--gr);flex-shrink:0;letter-spacing:0.03em;}
.bt{font-size:9px;font-weight:600;padding:2px 6px;border-radius:20px;background:var(--am-dim);color:var(--am);flex-shrink:0;cursor:pointer;letter-spacing:0.03em;}
.mblk{border:1px solid var(--bd);border-radius:var(--rad);overflow:hidden;}
.mo{position:fixed;inset:0;background:rgba(29,31,44,0.4);z-index:100;display:none;align-items:flex-start;justify-content:flex-end;}
.mo.show{display:flex;}
.mp{width:380px;height:100%;background:var(--bg-s);overflow-y:auto;padding:20px;animation:si 0.2s ease;border-left:1px solid var(--bd);}
@keyframes si{from{transform:translateX(100%)}to{transform:none}}
.mh{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px;padding-bottom:13px;border-bottom:1px solid var(--bd);}
.mt{font-size:9px;font-weight:600;letter-spacing:0.08em;text-transform:uppercase;color:var(--tx3);}
.mx{font-size:16px;color:var(--tx3);cursor:pointer;user-select:none;line-height:1;font-weight:300;transition:color 0.1s;}
.mx:hover{color:var(--tx);}
.fld{margin-bottom:12px;}
.lbl{display:block;font-size:9px;font-weight:600;text-transform:uppercase;letter-spacing:0.08em;color:var(--tx3);margin-bottom:4px;}
textarea,input[type=text]{width:100%;border:1px solid var(--bd2);border-radius:var(--rad-sm);padding:7px 10px;font-size:12px;background:var(--bg-s2);color:var(--tx);outline:none;resize:vertical;line-height:1.5;}
textarea{min-height:60px;}
textarea:focus,input[type=text]:focus{border-color:var(--copper-bd);}
.save{display:inline-flex;font-size:11px;font-weight:600;letter-spacing:0.05em;text-transform:uppercase;color:var(--tx);cursor:pointer;user-select:none;transition:opacity 0.15s;border-bottom:1.5px solid var(--tx);}
.save:hover{opacity:0.5;}
.scan{font-size:11px;font-weight:500;color:var(--tx3);background:none;border:none;outline:none;cursor:pointer;padding:0 0 0 6px;transition:color 0.1s;}
.scan:hover{color:var(--copper);}
.logo-z{width:100%;height:48px;border:1px dashed var(--bd2);border-radius:var(--rad-sm);display:flex;align-items:center;justify-content:center;gap:7px;cursor:pointer;transition:border-color 0.15s,background 0.15s;background:var(--bg-s2);}
.logo-z:hover{border-color:var(--copper-bd);background:var(--copper-lt);}
.logo-z span{font-size:11px;font-weight:500;color:var(--tx3);}
.logo-z svg{width:13px;height:13px;color:var(--tx3);}
.logo-img{max-height:32px;max-width:100px;object-fit:contain;border-radius:3px;}
.m-toggle{font-size:11px;font-weight:500;color:var(--tx3);cursor:pointer;user-select:none;transition:color 0.1s;}
.m-toggle.on{color:var(--copper);}
.m-cat{font-size:9px;font-weight:600;text-transform:uppercase;letter-spacing:0.08em;color:var(--tx3);padding:14px 0 6px;display:flex;align-items:center;justify-content:space-between;}
.m-cat:first-child{padding-top:4px;}
.m-prow{display:flex;align-items:flex-start;gap:10px;padding:10px 0;border-bottom:1px solid var(--bd);}
.m-prow:last-of-type{border-bottom:none;}
.m-pdot{width:7px;height:7px;border-radius:50%;flex-shrink:0;margin-top:3px;}
.m-pdot.on{background:var(--gr);}
.m-pdot.off{background:transparent;border:1.5px solid #D0CCC6;}
.m-pname{font-size:12px;font-weight:600;color:var(--tx);letter-spacing:-0.01em;margin-bottom:2px;}
.m-pangles{font-size:11px;color:var(--tx3);line-height:1.4;}
.m-pacts{display:none;align-items:center;gap:8px;margin-left:auto;flex-shrink:0;}
.editing .m-pacts{display:flex;}
.m-add{font-size:10px;font-weight:600;color:var(--copper);cursor:pointer;user-select:none;opacity:0.75;}
.m-add:hover{opacity:1;}
.m-del{font-size:13px;color:#C0BAB4;cursor:pointer;user-select:none;line-height:1;}
.m-del:hover{color:var(--re);}
.m-addrow{display:none;padding:8px 0;}
.editing .m-addrow{display:flex;}
.m-addcat{display:none;padding-top:12px;border-top:1px solid var(--bd);margin-top:4px;}
.editing .m-addcat{display:flex;}
.m-link{font-size:10px;font-weight:600;letter-spacing:0.04em;text-transform:uppercase;color:var(--tx3);cursor:pointer;user-select:none;}
.m-link:hover{color:var(--copper);}
.vr{font-size:11px;color:var(--gr);background:var(--gr-dim);padding:10px 12px;border-radius:var(--rad-sm);line-height:1.6;margin-bottom:12px;border-left:2px solid var(--gr);}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:0.4}}

.calc-wrap{flex:1;overflow-y:auto;}
.calc-menu{padding:28px 32px;}
.calc-menu-title{font-size:9px;font-weight:600;text-transform:uppercase;letter-spacing:0.08em;color:var(--tx3);margin-bottom:16px;}
.cpa-view{padding:24px 28px;animation:fu 0.18s ease both;}
.cpa-hdr{display:flex;align-items:baseline;gap:12px;margin-bottom:20px;padding-bottom:16px;border-bottom:2px solid var(--bd);}
.cpa-title-row{display:flex;align-items:center;gap:10px;margin-bottom:20px;padding-bottom:16px;border-bottom:1px solid var(--bd);}
.cpa-back{font-size:11px;color:var(--tx3);cursor:pointer;user-select:none;transition:color 0.1s;display:inline-flex;align-items:center;gap:4px;}
.cpa-back:hover{color:var(--tx2);}
.cpa-pg-title{font-size:18px;font-weight:700;color:var(--tx);letter-spacing:-0.03em;}
.cpa-summary-pill{font-size:11px;font-weight:500;color:var(--tx2);background:var(--bg-s2);border:1px solid var(--bd);border-radius:20px;padding:3px 10px;margin-left:auto;}
.cpa-section{margin-bottom:4px;}
.cpa-cat-label{font-size:9px;font-weight:600;text-transform:uppercase;letter-spacing:0.08em;color:var(--tx3);padding:14px 0 6px;}
.cpa-row{display:flex;align-items:center;gap:12px;padding:10px 0;border-bottom:1px solid var(--bd);}
.cpa-row:last-child{border-bottom:none;}
.cpa-prod-name{font-size:11px;font-weight:600;color:var(--tx2);width:120px;flex-shrink:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;}
.cpa-angle-name{font-size:12px;font-weight:500;color:var(--tx);flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;}
.cpa-input-wrap{display:flex;align-items:center;gap:2px;border:1px solid var(--bd2);border-radius:var(--rad-sm);background:var(--bg-s2);padding:0 8px;width:90px;flex-shrink:0;}
.cpa-input-wrap:focus-within{border-color:var(--copper-bd);}
.cpa-dollar{font-size:12px;font-weight:600;color:var(--tx3);}
.cpa-input{border:none;background:transparent;font-size:12px;font-weight:600;color:var(--tx);width:54px;outline:none;padding:6px 2px;font-family:var(--f);}
.cpa-input::placeholder{color:var(--tx3);font-weight:400;}
.cpa-conf{display:flex;gap:4px;flex-shrink:0;}
.cpa-conf-btn{font-size:10px;font-weight:600;padding:3px 8px;border-radius:20px;border:1px solid var(--bd2);background:transparent;color:var(--tx3);cursor:pointer;user-select:none;transition:all 0.1s;white-space:nowrap;}
.cpa-conf-btn:hover{border-color:var(--bd2);color:var(--tx2);}
.cpa-empty-conf{font-size:11px;color:var(--tx3);font-style:italic;width:220px;flex-shrink:0;}
.cpa-portfolio{background:var(--bg-sb);border:1px solid var(--bd);border-radius:var(--rad);padding:14px 16px;margin-bottom:20px;display:flex;gap:24px;}
.cpa-stat{display:flex;flex-direction:column;gap:2px;}
.cpa-stat-val{font-size:20px;font-weight:700;color:var(--tx);letter-spacing:-0.03em;}
.cpa-stat-lbl{font-size:10px;color:var(--tx3);font-weight:500;}

/* ─── Performance Model ─── */
.pm-wrap{padding:22px 28px;animation:fu 0.18s ease both;}
.pm-toprow{display:flex;align-items:center;gap:8px;margin-bottom:8px;}
.pm-back{font-size:11px;color:var(--tx3);cursor:pointer;display:inline-flex;align-items:center;gap:4px;transition:color 0.1s;user-select:none;}
.pm-back:hover{color:var(--tx2);}
.pm-title{font-size:18px;font-weight:700;color:var(--tx);letter-spacing:-0.03em;}
.pm-ctrl{display:flex;align-items:center;gap:10px;padding-bottom:8px;border-bottom:1px solid var(--bd);margin-bottom:0;}
.pm-sc-wrap{position:relative;}
.pm-sc-btn{display:inline-flex;align-items:center;gap:4px;font-size:11px;font-weight:600;color:var(--copper);cursor:pointer;border-bottom:1px solid var(--copper);padding-bottom:1px;white-space:nowrap;user-select:none;}
.pm-sc-btn:hover{opacity:0.65;}
.pm-sc-dd{position:absolute;top:calc(100%+6px);left:0;background:#fff;border:1px solid var(--bd2);border-radius:var(--rad);box-shadow:0 4px 16px rgba(29,31,44,0.1);z-index:100;display:none;min-width:170px;overflow:hidden;}
.pm-sc-dd.show{display:block;}
.pm-sc-item{padding:7px 12px;font-size:12px;font-weight:500;color:var(--tx2);cursor:pointer;display:flex;align-items:center;gap:7px;transition:background 0.1s;}
.pm-sc-item:hover{background:var(--bg-sb);}
.pm-sc-item.on{color:var(--tx);}
.pm-sc-dot{width:5px;height:5px;border-radius:50%;background:var(--copper);visibility:hidden;}
.pm-sc-item.on .pm-sc-dot{visibility:visible;}
.pm-sc-new{padding:7px 12px;font-size:11px;font-weight:600;color:var(--copper);cursor:pointer;border-top:1px solid var(--bd);}
.pm-sc-new:hover{background:var(--copper-lt);}
.pm-save{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:0.02em;color:var(--tx);cursor:pointer;border-bottom:1.5px solid var(--tx);padding-bottom:1px;transition:opacity 0.15s;user-select:none;}
.pm-save:hover{opacity:0.5;}
.pm-sp{flex:1;}
.pm-mode{display:flex;align-items:center;border:1px solid var(--bd2);border-radius:20px;overflow:hidden;flex-shrink:0;}
.pm-mode-btn{font-size:10px;font-weight:600;padding:4px 11px;cursor:pointer;color:var(--tx3);background:transparent;white-space:nowrap;transition:all 0.12s;user-select:none;}
.pm-mode-btn.on{background:var(--tx);color:var(--cream);}
.pm-per{display:flex;align-items:center;gap:4px;flex-shrink:0;}
.pm-per-lbl{font-size:10px;color:var(--tx3);}
.pm-pbtn{font-size:10px;font-weight:600;padding:3px 9px;border-radius:20px;border:1px solid var(--bd2);background:transparent;color:var(--tx2);cursor:pointer;transition:all 0.12s;user-select:none;}
.pm-pbtn.on{background:var(--tx);color:var(--cream);border-color:var(--tx);}
.pm-period-line{display:flex;align-items:center;gap:4px;padding:7px 0 11px;font-size:11px;color:var(--tx3);}
.pm-period-lbl{font-weight:500;color:var(--tx3);}
.pm-date-disp{font-size:11px;font-weight:500;color:var(--tx2);cursor:pointer;border-bottom:1px dashed var(--bd2);transition:all 0.1s;}
.pm-date-disp:hover{color:var(--tx);border-bottom-color:var(--copper);}
.pm-date-disp.hidden{display:none;}
.pm-date-inp-wrap{display:none;}
.pm-date-inp-wrap.show{display:inline-flex;}
input.pm-date-inp{-webkit-appearance:none;font-family:var(--f);font-size:11px;font-weight:500;color:var(--tx);background:transparent;border:none;border-bottom:1.5px solid var(--copper);outline:none;padding:1px 1px;width:92px;cursor:pointer;}
input.pm-date-inp::-webkit-calendar-picker-indicator{opacity:0.3;width:10px;height:10px;cursor:pointer;}
.pm-date-sep{color:var(--tx3);}
.pm-days{color:var(--tx3);}
.pm-sum{display:flex;align-items:flex-start;padding-bottom:14px;border-bottom:1px solid var(--bd);margin-bottom:18px;}
.pm-sum-item{flex:1;padding:0 16px;border-right:1px solid var(--bd);}
.pm-sum-item:first-child{padding-left:0;}
.pm-sum-item:last-child{border-right:none;}
.pm-sum-lbl{font-size:9px;font-weight:600;text-transform:uppercase;letter-spacing:0.07em;color:var(--tx3);margin-bottom:4px;}
.pm-sum-val{font-size:16px;font-weight:700;color:var(--tx);letter-spacing:-0.02em;}
.pm-sum-val.green{color:var(--gr);}
.pm-sum-sub{font-size:10px;color:var(--tx3);margin-top:2px;}
.pm-sum-sub.over{color:var(--re);}
.pm-ch-head{display:flex;align-items:center;gap:8px;padding:11px 0 9px;border-bottom:1px solid var(--bd2);}
.pm-ch-dot{width:6px;height:6px;border-radius:50%;flex-shrink:0;}
.pm-dm{background:#1877F2;}.pm-da{background:#FF4B00;}.pm-dt{background:#222;}
.pm-ch-buddisp{display:flex;align-items:baseline;gap:4px;}
.pm-ch-lbl{font-size:9px;font-weight:600;text-transform:uppercase;letter-spacing:0.08em;color:var(--tx2);}
.pm-ch-alloc{font-size:12px;font-weight:600;color:var(--tx);}
.pm-ch-slash{font-size:11px;color:var(--tx3);}
.pm-ch-total-ced{display:inline-flex;cursor:text;}
.pm-ch-total-val{font-size:12px;font-weight:500;color:var(--tx2);}
.pm-ch-total-inp{font-size:12px;font-weight:500;color:var(--tx);background:transparent;border:none;border-bottom:1.5px solid var(--copper);outline:none;width:46px;padding:1px 0;font-family:var(--f);display:none;}
.pm-rem{font-size:10px;font-weight:500;padding:2px 7px;border-radius:20px;margin-left:4px;}
.pm-rem-ok{background:var(--gr-dim);color:var(--gr);}
.pm-rem-over{background:var(--re-dim);color:var(--re);}
.pm-rem-zero{background:var(--bd);color:var(--tx3);}
.pm-ch-right{display:flex;align-items:center;gap:10px;margin-left:auto;}
.pm-ch-ord{font-size:11px;color:var(--tx3);}
.pm-ch-ord strong{color:var(--tx2);font-weight:600;}
.pm-ch-acts{display:flex;gap:2px;}
.pm-ch-act{font-size:13px;color:var(--tx3);cursor:pointer;padding:2px 5px;border-radius:3px;line-height:1.2;transition:all 0.1s;user-select:none;}
.pm-ch-act:hover{color:var(--tx2);}
.pm-ch-act.rm:hover{color:var(--re);}
.pm-tbl{width:100%;border-collapse:collapse;}
.pm-th{font-size:9px;font-weight:600;text-transform:uppercase;letter-spacing:0.06em;color:var(--tx3);padding:7px 8px;text-align:right;border-bottom:1px solid var(--bd);}
.pm-th.left{text-align:left;}
.pm-cat td{padding:0;}
.pm-cat-lbl{font-size:9px;font-weight:600;text-transform:uppercase;letter-spacing:0.07em;color:var(--tx3);padding:10px 8px 4px;display:block;}
.pm-prod-hdr td{background:var(--bg-sb);padding:0;border-bottom:none;}
.pm-prod-cell{display:flex;align-items:center;gap:8px;padding:8px 8px 6px;}
.pm-pname{font-size:12px;font-weight:600;color:var(--tx);}
.pm-aov-wrap{display:flex;align-items:center;gap:3px;margin-left:auto;}
.pm-aov-lbl{font-size:10px;color:var(--tx3);}
.pm-aov-ced{display:inline-flex;align-items:center;gap:1px;cursor:text;}
.pm-aov-sym{font-size:11px;color:var(--tx3);}
.pm-aov-val{font-size:11px;font-weight:600;color:var(--tx2);}
.pm-aov-empty{font-size:11px;color:var(--tx3);}
.pm-aov-inp{font-size:11px;font-weight:600;color:var(--tx);background:transparent;border:none;border-bottom:1.5px solid var(--copper);outline:none;width:42px;padding:1px 0;font-family:var(--f);display:none;text-align:right;}
.pm-sub-row td{border-bottom:1px solid var(--bd);}
.pm-sub-row:last-child td{border-bottom:1px solid var(--bd2);}
.pm-sub-cell{display:flex;align-items:center;gap:7px;padding:7px 8px 7px 20px;}
.pm-sub-type{font-size:10px;font-weight:600;letter-spacing:0.04em;color:var(--tx3);width:28px;flex-shrink:0;}
.pm-sdot{width:6px;height:6px;border-radius:50%;flex-shrink:0;}
.pm-sg{background:var(--gr);}.pm-sa{background:var(--am);}.pm-sr{background:var(--re);}.pm-sn{background:var(--tx3);opacity:0.35;}.pm-sb{background:var(--bl);}
.pm-vtd{text-align:right;padding:7px 8px;vertical-align:middle;}
.pm-ced{display:inline-flex;align-items:center;justify-content:flex-end;cursor:text;gap:1px;}
.pm-ced-sym{font-size:11px;color:var(--tx3);}
.pm-ced-val{font-size:12px;font-weight:500;color:var(--tx);}
.pm-ced-empty{font-size:12px;color:var(--tx3);}
.pm-ced-inp{font-size:12px;font-weight:500;color:var(--tx);background:transparent;border:none;border-bottom:1.5px solid var(--copper);outline:none;width:46px;text-align:right;padding:1px 0;font-family:var(--f);display:none;}
.pm-bud-cell{display:inline-flex;align-items:baseline;justify-content:flex-end;gap:3px;cursor:text;}
.pm-bud-alloc{font-size:12px;font-weight:500;}
.pm-bud-empty{color:var(--tx3);}
.pm-bud-has{color:var(--tx);}
.pm-bud-of{font-size:10px;color:var(--tx3);}
.pm-bud-total{font-size:10px;color:var(--tx3);}
.pm-bud-inp{font-size:12px;font-weight:500;color:var(--tx);background:transparent;border:none;border-bottom:1.5px solid var(--copper);outline:none;width:52px;text-align:right;padding:1px 0;font-family:var(--f);display:none;}
.pm-roas{font-size:11px;color:var(--tx3);}
.pm-roas.has{color:var(--tx2);font-weight:500;}
.pm-hv{font-size:11px;font-weight:500;}
.pm-hv.ok{color:var(--gr);}.pm-hv.am{color:var(--am);}.pm-hv.re{color:var(--re);}.pm-hv.na{color:var(--tx3);opacity:0.4;}
.pm-est{font-size:12px;font-weight:600;color:var(--tx);}
.pm-est-na{font-size:12px;color:var(--tx3);opacity:0.3;}
.pm-rev{font-size:11px;color:var(--tx2);}
.pm-rev-na{font-size:11px;color:var(--tx3);opacity:0.3;}
.pm-foot td{background:var(--bg-sb);border-top:1px solid var(--bd);padding:7px 8px;font-size:11px;font-weight:600;color:var(--tx2);text-align:right;}
.pm-foot .lft{text-align:left;color:var(--tx3);}
.pm-ch-div{height:1px;background:var(--bd);margin-bottom:4px;}
.pm-add{padding-top:12px;display:flex;gap:12px;}
.pm-add-btn{font-size:10px;font-weight:600;letter-spacing:0.04em;text-transform:uppercase;color:var(--tx3);background:none;border:none;cursor:pointer;padding:0;font-family:var(--f);transition:color 0.1s;}
.pm-add-btn:hover{color:var(--copper);}

.mr-inp{font-size:11px;padding:3px 6px;border:1px solid var(--copper);border-radius:3px;background:var(--bg-s);color:var(--tx);outline:none;width:120px;}

.fd-dates{display:flex;align-items:center;gap:8px;margin-top:8px;padding-top:8px;border-top:1px solid var(--bd);}
.fd-date-lbl{font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:0.06em;color:var(--tx3);width:72px;flex-shrink:0;}
.fd-date-inp{font-size:11px;padding:4px 7px;border:1px solid var(--bd2);border-radius:var(--rad-sm);background:var(--bg-s);color:var(--tx);outline:none;}
.fd-date-inp:focus{border-color:var(--copper);}

.mr-sel{font-size:11px;padding:3px 6px;border:1px solid var(--copper);border-radius:3px;background:var(--bg-s);color:var(--tx);outline:none;cursor:pointer;}

.pm-map-tbl td,.pm-map-tbl th{padding:5px 8px;white-space:nowrap;}
.pm-ba{display:inline-block;cursor:pointer;}
.pm-ba:hover{opacity:0.8;}

.pm-empty{color:var(--tx3);font-size:13px;cursor:pointer;padding:2px 6px;border-radius:3px;opacity:0.4;}
.pm-empty:hover{opacity:1;color:var(--copper);}

/* ─── Perf page ─────────────────────────────────────────────────────────── */
.perf-filters{display:flex;align-items:flex-start;gap:24px;padding:16px 24px;border-bottom:1px solid var(--bd);flex-shrink:0;flex-wrap:wrap;}
.perf-filter-group{display:flex;flex-direction:column;gap:6px;}
.perf-filter-lbl{font-size:9px;font-weight:600;text-transform:uppercase;letter-spacing:.08em;color:var(--tx3);}
.perf-chip-row{display:flex;gap:4px;flex-wrap:wrap;}
.perf-chip{font-size:11px;font-weight:500;padding:3px 10px;border-radius:12px;border:1px solid var(--bd2);color:var(--tx3);cursor:pointer;transition:all .15s;white-space:nowrap;}
.perf-chip:hover{border-color:var(--copper);color:var(--copper);}
.perf-chip.active{background:var(--copper);border-color:var(--copper);color:var(--cream);}
.perf-summary-hdr{padding:20px 24px 0;}
.perf-stat-strip{display:flex;gap:1px;background:var(--bd);border-radius:var(--rad-sm);overflow:hidden;margin-bottom:16px;}
.perf-stat{flex:1;background:var(--bg-s);padding:12px 14px;}
.perf-stat-lbl{font-size:9px;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:var(--tx3);margin-bottom:4px;}
.perf-stat-val{font-size:18px;font-weight:700;color:var(--tx);line-height:1;}
.perf-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px;padding:0 24px 12px;}
.perf-card{background:var(--bg-s);border:1px solid var(--bd);border-radius:var(--rad-sm);padding:16px;}
.perf-card-t{font-size:11px;font-weight:600;color:var(--tx2);margin-bottom:12px;text-transform:uppercase;letter-spacing:.04em;}
.perf-lb-row,.perf-lb-head{display:flex;align-items:baseline;gap:10px;padding:7px 0;border-bottom:1px solid var(--bd);}
.perf-lb-row:last-child{border-bottom:none;}
.perf-lb-rank{font-size:10px;font-weight:700;color:var(--tx3);width:22px;flex-shrink:0;}
.perf-lb-name{flex:2;font-size:10px;color:var(--tx2);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;}
.perf-lb-meta{flex:1.5;font-size:10px;color:var(--tx3);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;}
.perf-lb-funnel{width:80px;font-size:10px;color:var(--tx3);flex-shrink:0;}
.perf-lb-spend{width:64px;font-size:10px;color:var(--tx2);text-align:right;flex-shrink:0;}
.perf-lb-conv{width:40px;font-size:10px;color:var(--tx2);text-align:right;flex-shrink:0;}
.perf-lb-cpa{width:56px;font-size:11px;font-weight:700;text-align:right;flex-shrink:0;}



/* ── Unified status identifier badges ───────────────────────────────────────
   The identifier IS the status. Badge color = state. No separate status
   column or pill needed. Applied to P-numbers, HL-numbers, EXP identifiers.
   Same language across Track, Intel, Experiments, Creative.
──────────────────────────────────────────────────────────────────────────── */
.id-badge{font-size:10px;font-weight:700;font-family:monospace;padding:2px 7px;border-radius:3px;white-space:nowrap;display:inline-block;letter-spacing:.02em;line-height:1.5}
/* No borders on any id-badge — status is communicated through fill color alone */
/* Active — copper fill, cream text: warm, prominent, live */
.id-badge-active{background:var(--copper);color:var(--cream)}
/* Backlog — slightly darker than page bg so it reads without a border */
.id-badge-backlog{background:rgba(29,31,44,.08);color:var(--tx3)}
/* Completed — blue-tinted fill, same visual weight as active */
.id-badge-completed{background:var(--bl-dim);color:var(--bl)}
/* Experiment — amber fill, same visual weight */
.id-badge-exp{background:var(--am-dim);color:var(--am)}
/* Paused — red-dim fill */
.id-badge-paused{background:var(--re-dim);color:var(--re)}

/* Sidebar dot — same status vocabulary as id-badge ────────────────────────
   .dot.active  = copper  (entity is live / has live paths)
   .dot.on      = green   (entity has content but may not be live — kept for section dots)
   .dot.off     = grey    (entity is empty / not started)
──────────────────────────────────────────────────────────────────────────── */
.dot.active{background:var(--copper)}
.dot.exp{background:var(--am);animation:pulse 1.2s infinite}


/* ── Date range picker (shared across all pages) ────────────────────────────
   Dropdown picker with presets (Today/Yesterday/7d/30d/90d) + custom range.
   Usage: buildDRP(container, onChange) in any page script.
──────────────────────────────────────────────────────────────────────────── */
.drp{position:relative;display:inline-block}
.drp-btn{font-size:11px;font-weight:600;padding:4px 10px;border-radius:var(--rad-sm);border:1px solid var(--bd2);color:var(--tx2);background:var(--bg-s);cursor:pointer;display:inline-flex;align-items:center;gap:5px;white-space:nowrap;transition:all .15s}
.drp-btn:hover,.drp-btn.open{border-color:var(--copper);color:var(--tx)}
.drp-btn-chev{font-size:9px;color:var(--tx3)}
.drp-panel{position:absolute;top:calc(100% + 4px);right:0;background:#fff;border:1px solid var(--bd2);border-radius:var(--rad);box-shadow:0 4px 20px rgba(29,31,44,.12);z-index:200;min-width:210px;overflow:hidden;display:none}
.drp-panel.show{display:block}
.drp-preset{padding:7px 14px;font-size:12px;font-weight:500;color:var(--tx2);cursor:pointer;display:flex;align-items:center;justify-content:space-between;transition:background .1s;user-select:none}
.drp-preset:hover{background:var(--bg-sb)}
.drp-preset.sel{color:var(--tx);font-weight:600}
.drp-preset-chk{font-size:10px;color:var(--copper);visibility:hidden}
.drp-preset.sel .drp-preset-chk{visibility:visible}
.drp-divider{height:1px;background:var(--bd);margin:3px 0}
.drp-custom{padding:10px 14px 12px}
.drp-custom-lbl{font-size:9px;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--tx3);margin-bottom:8px}
.drp-date-row{display:flex;align-items:center;gap:8px;margin-bottom:6px;font-size:11px}
.drp-date-key{color:var(--tx3);width:28px;flex-shrink:0}
.drp-date-inp{flex:1;border:1px solid var(--bd2);border-radius:3px;padding:4px 6px;font-size:11px;color:var(--tx);outline:none;font-family:var(--f);background:var(--bg-s2)}
.drp-date-inp:focus{border-color:var(--copper)}
.drp-apply{width:100%;font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.04em;padding:6px;background:var(--copper);color:var(--cream);border:none;border-radius:3px;cursor:pointer;margin-top:4px;font-family:var(--f)}
.drp-apply:hover{opacity:.9}

/* ── AI shimmer ─────────────────────────────────────────────────────────────
   Flowing gradient on all AI-trigger elements.
   Text variant: gradient text sweep.
   Button variant: gradient background with glow.
──────────────────────────────────────────────────────────────────────────── */
@keyframes ai-flow {
  0%   { background-position: 0% 50%; }
  50%  { background-position: 100% 50%; }
  100% { background-position: 0% 50%; }
}
@keyframes ai-pulse {
  0%, 100% { opacity: 1; }
  50%       { opacity: 0.6; }
}

/* Text shimmer — for inline links like "✦ Discover brand ↗" */
.ai-text {
  background: linear-gradient(90deg,
    #C47B3A 0%,
    #E8B96A 20%,
    #8FD4C8 40%,
    #7B9EE8 60%,
    #C47B3A 80%,
    #E8B96A 100%
  );
  background-size: 250% auto;
  background-clip: text;
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  animation: ai-flow 5s linear infinite;
  font-weight: 600;
  cursor: pointer;
}
.ai-text:hover {
  animation-duration: 2s;
}

/* Button shimmer — for filled AI action buttons */
.ai-btn {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 7px 16px;
  border-radius: var(--rad-sm);
  border: 1.2px solid transparent;
  cursor: pointer;
  font-size: 12px;
  font-weight: 600;
  letter-spacing: 0.01em;
  transition: transform 0.15s;
  /* 3-layer: gradient text | solid fill | gradient border */
  background:
    linear-gradient(90deg, #C47B3A, #E8C06A, #8FD4C8, #7B9EE8, #C07BE8, #C47B3A),
    linear-gradient(var(--bg-s), var(--bg-s)),
    linear-gradient(90deg, #C47B3A, #E8C06A, #8FD4C8, #7B9EE8, #C07BE8, #C47B3A);
  background-clip: text, padding-box, border-box;
  -webkit-background-clip: text, padding-box, border-box;
  background-size: 300% auto, auto, 300% auto;
  -webkit-text-fill-color: transparent;
  animation: ai-flow 4s linear infinite;
}
.ai-btn:hover {
  transform: translateY(-1px);
  animation-duration: 1.8s;
}
.ai-btn:active {
  transform: scale(0.97);
}

/* Loading state — faster pulse while waiting */
.ai-btn.loading, .ai-text.loading {
  animation: ai-flow 1.2s linear infinite, ai-pulse 1.2s ease-in-out infinite;
}

/* Orb — the small animated indicator dot next to AI labels */
.ai-orb {
  display: inline-block;
  width: 7px;
  height: 7px;
  border-radius: 50%;
  background: linear-gradient(135deg, #C47B3A, #8FD4C8, #7B9EE8);
  background-size: 200% 200%;
  animation: ai-flow 3s ease infinite;
  vertical-align: middle;
  margin-right: 3px;
  flex-shrink: 0;
}

/* ── Shared modal classes (offers-manager.js, etc) ────────────────────────── */
/* These were originally inline in track.html only. Promoted to shared so the
   Offer Manager modal renders consistently on every page that loads it. */
.trk-mo{position:fixed;inset:0;background:rgba(0,0,0,.5);display:none;align-items:center;justify-content:center;z-index:200}
.trk-mo.open{display:flex}
.mb{background:var(--bg-s);border:1px solid var(--bd2);border-radius:var(--rad);padding:22px;width:520px;max-width:92vw;max-height:88vh;overflow-y:auto}
.mt2{font-size:13px;font-weight:700;color:var(--tx);margin-bottom:3px}
.ms2{font-size:11px;color:var(--tx3);margin-bottom:16px;line-height:1.5}
.mf{margin-bottom:12px}
.ml2{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--tx3);margin-bottom:4px;display:block}
.mi{width:100%;box-sizing:border-box;background:var(--bg);border:1px solid var(--bd2);border-radius:var(--rad-sm);padding:7px 9px;font-size:12px;color:var(--tx);font-family:inherit;outline:none;transition:border-color .15s}
.mi:focus{border-color:var(--copper)}
.mac{display:flex;gap:8px;justify-content:flex-end;margin-top:16px;padding-top:12px;border-top:1px solid var(--bd)}

/* Buttons used inside shared modals — minimal so pages without their own
   .btn rules still get sensible appearance. Pages that DO have .btn keep theirs. */
.btn{font-size:11px;font-weight:600;padding:7px 12px;border:1px solid var(--bd2);border-radius:var(--rad-sm);background:var(--bg);color:var(--tx);cursor:pointer;font-family:inherit;outline:none;transition:background .1s,border-color .1s}
.btn:hover{background:var(--bg-s2)}
.btn-c{background:var(--copper);color:#fff;border-color:var(--copper)}
.btn-c:hover{opacity:.92;background:var(--copper)}
.btn-xs{font-size:10px;padding:4px 8px}
.btn-sm{font-size:11px;padding:6px 10px}
.btn[disabled]{opacity:.55;cursor:wait}
