:root{
  --ink:#13151C;--ink-2:#1B1E28;--ink-3:#262A37;--ink-line:#2E3340;
  --canvas:#F4F5F8;--card:#FFFFFF;--line:#E6E8EE;--line-2:#EEF0F4;
  --text:#171922;--soft:#5A6172;--mute:#8B92A1;
  --accent:#3D55F0;--accent-soft:#EBEEFE;--accent-line:#C9D2FB;
  --ok:#0FAE91;--ok-soft:#E2F6F1;--warn:#D9870B;--warn-soft:#FBF0DC;
  --r:14px;--r-sm:9px;--r-lg:18px;
  --ink-soft:rgba(255,255,255,.62);--ink-mute:rgba(255,255,255,.40);
}
*{box-sizing:border-box}
html,body{margin:0}
body{font-family:'Inter',system-ui,sans-serif;background:var(--ink);color:var(--text);-webkit-font-smoothing:antialiased;line-height:1.5}
.app{display:grid;grid-template-columns:240px 1fr;grid-template-rows:58px 1fr;height:100vh;grid-template-areas:"top top" "side main"}
.top{grid-area:top;background:var(--ink);border-bottom:1px solid var(--ink-line);display:flex;align-items:center;justify-content:space-between;padding:0 18px;gap:14px}
.brand{display:flex;align-items:center;gap:11px;min-width:0}
.logo{width:32px;height:32px;border-radius:9px;background:linear-gradient(135deg,var(--accent),#6F7FF6);display:flex;align-items:center;justify-content:center;font-family:'Space Grotesk';font-weight:700;color:#fff;font-size:14px;letter-spacing:.5px}
.brand b{font-family:'Space Grotesk';font-weight:600;color:#fff;font-size:14.5px}
.brand .sub{color:var(--ink-mute);font-size:12px;margin-left:2px}
.tag{font-size:11px;color:var(--ink-soft);border:1px solid var(--ink-line);border-radius:999px;padding:4px 11px;white-space:nowrap}
.menu-btn{display:none;background:none;border:1px solid var(--ink-line);border-radius:9px;width:36px;height:36px;color:#fff;align-items:center;justify-content:center;cursor:pointer}
.side{grid-area:side;background:var(--ink);border-right:1px solid var(--ink-line);padding:16px 12px;overflow-y:auto}
.nav-item{display:flex;align-items:center;gap:11px;padding:10px;border-radius:10px;color:var(--ink-soft);text-decoration:none;font-size:13.5px;font-weight:450;transition:background .15s,color .15s;margin-bottom:3px;cursor:pointer;border:none;background:transparent;width:100%;text-align:left}
.nav-item svg{width:18px;height:18px;stroke:currentColor;opacity:.85;flex-shrink:0}
.nav-item:hover{background:var(--ink-2);color:#fff}
.nav-item.current{background:var(--ink-3);color:#fff}
.nav-item.current svg{opacity:1}
.nav-item .n{margin-left:auto;font-family:'Space Mono';font-size:11px;color:var(--ink-mute)}
.navsep{height:1px;background:var(--ink-line);margin:10px 8px}
.main{grid-area:main;background:var(--canvas);overflow-y:auto;padding:26px clamp(16px,4vw,40px)}
.wrap{max-width:840px;margin:0 auto}
.head{display:flex;align-items:flex-start;justify-content:space-between;gap:14px;margin-bottom:18px;flex-wrap:wrap}
.h1{font-family:'Space Grotesk';font-weight:600;font-size:22px;letter-spacing:-.01em;margin:0 0 3px}
.lead{color:var(--soft);font-size:13.5px;margin:0;max-width:64ch}
@keyframes fade{from{opacity:0;transform:translateY(6px)}to{opacity:1;transform:none}}
.card{background:var(--card);border:1px solid var(--line);border-radius:var(--r-lg);padding:20px 22px}
.card+.card{margin-top:14px}
.ttl{font-weight:600;font-size:14.5px;margin:0 0 14px;font-family:'Space Grotesk'}
.sub-h{font-size:12px;letter-spacing:.1em;text-transform:uppercase;color:var(--mute);font-weight:600;margin:22px 0 11px}
.field{margin-bottom:12px}
.field label{display:block;font-size:12px;color:var(--soft);margin-bottom:5px;font-weight:500}
input.in,select.in,textarea.in{width:100%;border:1px solid var(--line);background:#fff;border-radius:10px;padding:10px 12px;font:inherit;font-size:13.5px;color:var(--text)}
input.in::placeholder,textarea.in::placeholder{color:var(--mute)}
input.in:focus,select.in:focus,textarea.in:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft)}
.row2{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.row3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:10px}
.btn{display:inline-flex;align-items:center;gap:8px;border:1px solid var(--line);background:#fff;color:var(--text);border-radius:10px;padding:9px 15px;font:inherit;font-size:13.5px;font-weight:500;cursor:pointer;text-decoration:none;transition:.15s}
.btn:hover{border-color:var(--mute)}
.btn svg{width:16px;height:16px;stroke:currentColor}
.btn.primary{background:var(--accent);border-color:var(--accent);color:#fff}
.btn.primary:hover{background:#3247d8}
.btn.block{width:100%;justify-content:center}
.btn.sm{padding:6px 11px;font-size:12.5px;border-radius:9px}
.btn.sm svg{width:14px;height:14px}
.btn.warn{background:var(--warn);border-color:var(--warn);color:#fff}
.btn:disabled,.btn.disabled{opacity:.5;cursor:not-allowed}
.ghost.btn{background:none;border-color:transparent;color:var(--mute)}
.ghost.btn:hover{background:#fff;border-color:var(--line);color:var(--text)}
.token{display:flex;align-items:center;gap:11px;background:var(--ink);color:#fff;border-radius:12px;padding:12px 15px;margin-bottom:16px;flex-wrap:wrap}
.token svg{width:16px;height:16px;stroke:#fff;opacity:.75}
.token b{font-family:'Space Mono';letter-spacing:.5px;font-size:14px}
.token .lab{color:var(--ink-soft);font-size:12.5px}
.token .pk{margin-left:auto;font-size:10.5px;border:1px solid var(--ink-line);border-radius:999px;padding:3px 9px;color:var(--ink-soft)}
.subtabs{display:flex;gap:4px;flex-wrap:wrap;margin-bottom:16px;border-bottom:1px solid var(--line)}
.subtabs a,.subtabs button{background:none;border:none;border-bottom:2px solid transparent;padding:9px 13px;font:inherit;font-size:13px;color:var(--soft);cursor:pointer;margin-bottom:-1px;text-decoration:none}
.subtabs a:hover,.subtabs button:hover{color:var(--text)}
.subtabs a.on,.subtabs button.on{color:var(--accent);border-bottom-color:var(--accent);font-weight:600}
.subtabs-inset{padding:10px 12px;background:#fff;border:1px solid var(--line);border-radius:12px;margin-bottom:16px}
.subtabs-inset a,.subtabs-inset button{padding:7px 12px;font-size:12.5px}
.subpanel{display:none}
.subpanel.on{display:block;animation:fade .2s ease}
.kpis{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:12px;margin-bottom:6px}
.kpi{background:#fff;border:1px solid var(--line);border-radius:var(--r);padding:15px 16px}
.kpi .k{font-size:12.5px;color:var(--soft);margin:0 0 6px;display:flex;align-items:center;gap:6px}
.kpi .k svg{width:14px;height:14px;stroke:currentColor}
.kpi .v{font-family:'Space Grotesk';font-weight:600;font-size:26px;margin:0;letter-spacing:-.01em}
.kpi .kf{font-size:11.5px;color:var(--mute);margin:6px 0 0}
.ev{display:flex;align-items:center;gap:14px;background:#fff;border:1px solid var(--line);border-radius:var(--r-lg);padding:15px 17px}
.ev+.ev{margin-top:10px}
.ev .ic{width:44px;height:44px;border-radius:11px;background:var(--accent-soft);color:var(--accent);display:flex;align-items:center;justify-content:center;flex-shrink:0}
.ev .ic.live{background:var(--ok-soft);color:var(--ok)}
.ev .ic svg{width:22px;height:22px;stroke:currentColor}
.ev .body{flex:1;min-width:0}
.ev .nm{font-weight:500;font-size:14.5px;font-family:'Space Grotesk'}
.ev .meta{font-size:12.5px;color:var(--soft);margin-top:2px;display:flex;gap:12px;flex-wrap:wrap}
.ev .meta span{display:flex;align-items:center;gap:5px}
.ev .meta svg{width:13px;height:13px;stroke:currentColor;vertical-align:-2px}
.st{font-size:11px;font-weight:600;padding:4px 10px;border-radius:999px;white-space:nowrap;display:inline-flex;align-items:center;gap:6px}
.st.live{background:var(--ok-soft);color:var(--ok)}
.st.sched{background:var(--accent-soft);color:var(--accent)}
.st.expired{background:var(--warn-soft);color:var(--warn)}
.st.closed{background:#FEE2E2;color:#991B1B}
.st.draft{background:var(--canvas);color:var(--soft)}
.ev-act{display:flex;align-items:center;gap:8px;flex-shrink:0}
.evdup{width:34px;height:34px;border-radius:9px;border:1px solid var(--line);background:#fff;color:var(--soft);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:.15s;text-decoration:none;padding:0;font:inherit}
.evdup:hover{border-color:var(--accent);color:var(--accent)}
.evdup svg{width:16px;height:16px;stroke:currentColor}
.vtog{display:inline-flex;background:var(--canvas);border:1px solid var(--line);border-radius:10px;padding:3px}
.vtog button{border:none;background:none;padding:6px 14px;border-radius:8px;font:inherit;font-size:13px;color:var(--soft);cursor:pointer}
.vtog button.on{background:#fff;color:var(--text);font-weight:500;box-shadow:0 1px 3px rgba(0,0,0,.08)}
.ag-month{font-size:12px;letter-spacing:.08em;text-transform:uppercase;color:var(--mute);font-weight:600;margin:18px 0 10px}
.ag-row{display:flex;align-items:center;gap:14px;background:#fff;border:1px solid var(--line);border-radius:var(--r-lg);padding:13px 16px}
.ag-row+.ag-row{margin-top:8px}
.ag-date{width:52px;text-align:center;flex-shrink:0;border-right:1px solid var(--line-2);padding-right:12px}
.ag-date .dd{font-family:'Space Grotesk';font-weight:600;font-size:20px;line-height:1}
.ag-date .mm{font-size:11px;color:var(--soft);text-transform:uppercase;margin-top:3px}
.ag-row .body2{flex:1;min-width:0}
.ag-row .nm2{font-weight:500;font-size:14px;font-family:'Space Grotesk'}
.ag-row .meta2{font-size:12.5px;color:var(--soft);margin-top:2px;display:flex;gap:12px;flex-wrap:wrap}
.ag-row .meta2 svg{width:13px;height:13px;stroke:currentColor;vertical-align:-2px}
.dotpulse{width:7px;height:7px;border-radius:50%;background:var(--ok)}
@media (prefers-reduced-motion:no-preference){.dotpulse{animation:pulse 1.6s ease-in-out infinite}}
@keyframes pulse{0%,100%{box-shadow:0 0 0 0 rgba(15,174,145,.5)}50%{box-shadow:0 0 0 5px rgba(15,174,145,0)}}
.livebar{margin-top:10px;height:7px;border-radius:4px;background:var(--line-2);overflow:hidden}
.livebar i{display:block;height:7px;border-radius:4px;background:var(--ok);transition:width .6s}
.mp{display:flex;align-items:center;gap:12px;padding:11px 0}
.mp+.mp{border-top:1px solid var(--line-2)}
.mp>svg{width:20px;height:20px;stroke:var(--soft);flex-shrink:0}
.mp .info{flex:1;min-width:0}
.mp .info p{margin:0;font-size:13.5px;font-weight:500}
.mp .info .d{font-size:12px;color:var(--soft);margin-top:1px}
.sw{width:40px;height:23px;border-radius:12px;background:var(--line);position:relative;flex-shrink:0;cursor:pointer;transition:background .18s;border:none}
.sw.on{background:var(--accent)}
.sw::after{content:"";position:absolute;left:2px;top:2px;width:19px;height:19px;border-radius:50%;background:#fff;transition:transform .18s}
.sw.on::after{transform:translateX(17px)}
.pers{font-size:10px;padding:2px 8px;border-radius:999px;background:var(--accent-soft);color:var(--accent);font-weight:600;margin-left:7px}
.rm{width:18px;height:18px;stroke:var(--mute);cursor:pointer;flex-shrink:0}
.rm:hover{stroke:var(--warn)}
.dropzone{border:1.5px dashed var(--line);border-radius:12px;padding:22px;text-align:center;color:var(--mute);background:var(--canvas)}
.dropzone svg{width:28px;height:28px;stroke:currentColor;margin-bottom:6px}
.builder{display:grid;grid-template-columns:1fr 1.15fr;gap:14px}
.col h4{font-size:11px;color:var(--soft);font-weight:600;margin:0 0 9px;text-transform:uppercase;letter-spacing:.08em}
.palette{display:flex;flex-direction:column;gap:8px}
.bz{display:flex;flex-direction:column;gap:8px;background:var(--canvas);border:1.5px dashed var(--line);border-radius:12px;padding:10px;min-height:200px}
.bz.dragover{border-color:var(--accent);background:var(--accent-soft)}
.bz-empty{color:var(--mute);font-size:12.5px;text-align:center;padding:40px 8px;margin:auto}
.fchip,.fitem{display:flex;align-items:center;gap:9px;background:#fff;border:1px solid var(--line);border-radius:10px;padding:9px 11px;font-size:13px}
.fchip{cursor:grab}
.fchip:hover{border-color:var(--accent-line)}
.fitem{cursor:grab}
.grip{width:16px;height:16px;color:var(--mute);flex-shrink:0}
.fchip .ty{margin-left:auto;font-size:11px;color:var(--mute)}
.fitem .req{margin-left:auto;font-size:10px;padding:2px 8px;border-radius:999px;background:var(--accent-soft);color:var(--accent);font-weight:600}
.hint{font-size:12px;color:var(--mute);margin:10px 0 0;display:flex;align-items:center;gap:6px}
.hint svg{width:14px;height:14px;stroke:currentColor}
.orsep{display:flex;align-items:center;gap:12px;margin:16px 0;color:var(--mute);font-size:12px}
.orsep::before,.orsep::after{content:"";flex:1;height:1px;background:var(--line)}
.radio{display:flex;align-items:center;gap:11px;padding:12px 14px;border:1px solid var(--line);border-radius:12px;cursor:pointer;margin-bottom:9px;background:#fff}
.radio.on{border:2px solid var(--accent);background:var(--accent-soft)}
.radio .dot{width:18px;height:18px;border-radius:50%;border:2px solid var(--mute);flex-shrink:0;position:relative}
.radio.on .dot{border-color:var(--accent)}
.radio.on .dot::after{content:"";position:absolute;inset:3px;border-radius:50%;background:var(--accent)}
.radio svg{width:18px;height:18px;stroke:var(--soft)}
.radio.on svg{stroke:var(--accent)}
.radio .lab{font-size:13.5px;font-weight:500}
.bg-block{display:grid;grid-template-columns:120px 1fr;gap:16px;align-items:center}
.bg-prev{height:104px;border-radius:12px;border:1px solid var(--line);display:flex;align-items:center;justify-content:center;color:#fff;font-size:12px;font-family:'Space Grotesk'}
.swatches{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:10px}
.swatch{width:30px;height:30px;border-radius:8px;cursor:pointer;border:2px solid transparent}
.swatch.on{border-color:var(--text);box-shadow:0 0 0 2px #fff inset}
.consent{display:flex;gap:9px;align-items:flex-start;background:var(--canvas);border-radius:10px;padding:11px 13px;font-size:12px;color:var(--soft);margin-top:12px}
.consent svg{width:18px;height:18px;stroke:var(--accent);flex-shrink:0;margin-top:1px}
.a-link{color:var(--accent);text-decoration:none;cursor:pointer}
.endbar{display:flex;justify-content:flex-end;gap:8px;margin-top:16px}
.muted{color:var(--soft);font-size:12.5px}
.landwrap{display:grid;grid-template-columns:1.3fr 1fr;gap:14px;align-items:start}
.lp{border-radius:var(--r-lg);overflow:hidden;border:1px solid var(--line)}
.lp .hero{padding:26px 22px;color:#fff}
.lp .hero .ev-n{font-family:'Space Grotesk';font-weight:600;font-size:18px}
.lp .hero .ev-m{font-size:12.5px;opacity:.85;margin-top:4px}
.lp .form{background:#fff;padding:18px}
.lp .form .ttl{font-size:13.5px}
.codebox{background:var(--ink);color:#E6E8EE;border-radius:10px;padding:12px 13px;font-family:'Space Mono';font-size:11.5px;line-height:1.6;overflow-x:auto;white-space:pre}
.land-stage{border-radius:var(--r-lg);padding:34px 20px;display:flex;flex-direction:column;align-items:center;gap:18px;background-size:cover;background-position:center;transition:background .3s}
.land-stage .lh{text-align:center;color:#fff}
.land-stage .lh .n{font-family:'Space Grotesk';font-weight:600;font-size:18px}
.land-stage .lh .m{font-size:12.5px;opacity:.88;margin-top:3px}
.land-card{background:#fff;border-radius:var(--r-lg);padding:22px 24px;width:100%;max-width:560px;box-shadow:0 14px 44px rgba(0,0,0,.20)}
.lc-head{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-bottom:16px;flex-wrap:wrap}
.lc-ttl{font-family:'Space Grotesk';font-weight:600;font-size:15px;margin:0}
.lc-imp{font-size:12px;color:var(--accent);display:flex;align-items:center;gap:5px}
.lc-imp svg{width:13px;height:13px;stroke:currentColor}
.lf-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.lf-grid .field{margin-bottom:0}
.lf-grid .field.wide{grid-column:1 / -1}
.lf-grid .consent.wide{grid-column:1 / -1;margin-top:4px}
.lf-grid .btn.block.wide{grid-column:1 / -1}
.linkrow{display:flex;align-items:center;gap:12px;padding:12px 14px;background:var(--canvas);border-radius:11px}
.linkrow>svg{width:22px;height:22px;stroke:var(--accent);flex-shrink:0}
.linkrow .info{flex:1;min-width:0}
.linkrow .info p{margin:0;font-size:13px;font-weight:500}
.linkrow .info .u{font-family:'Space Mono';font-size:11.5px;color:var(--soft);margin-top:1px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.qr{background:#fff;padding:11px;border:1px solid var(--line);border-radius:12px;display:inline-block}
.qr-row{display:flex;gap:18px;align-items:center;margin-top:16px;flex-wrap:wrap}
.qr-send{flex:1;min-width:210px}

.tg-ic{width:46px;height:46px;border-radius:12px;background:var(--accent-soft);color:var(--accent);display:flex;align-items:center;justify-content:center;margin:0 auto 12px}
.tg-ic svg{width:24px;height:24px;stroke:currentColor}
.tg-ttl{font-family:'Space Grotesk';font-weight:600;font-size:16px;margin:0 0 4px}
.tg-sub{font-size:12.5px;color:var(--soft);margin:0 0 16px}
.tg-err{font-size:12px;color:var(--warn);margin:10px 0 0}
.tg-hint{font-size:12px;color:var(--mute);margin:12px 0 0}
.tab-menu{width:100%;max-width:700px}
.topline{text-align:center;color:#fff;margin-bottom:18px}
.topline .tm-n{font-family:'Space Grotesk';font-weight:600;font-size:17px}
.topline .tm-m{font-size:12px;opacity:.85;margin-top:2px}
.tab-cards{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}
.tcard{background:#fff;border-radius:16px;padding:20px;cursor:pointer;transition:.16s;box-shadow:0 8px 24px rgba(0,0,0,.12);text-decoration:none;color:var(--text)}
.tcard:hover{transform:translateY(-3px);box-shadow:0 12px 30px rgba(0,0,0,.18)}
.tc-ic{width:44px;height:44px;border-radius:12px;background:var(--accent-soft);color:var(--accent);display:flex;align-items:center;justify-content:center;margin-bottom:12px}
.tc-ic svg{width:22px;height:22px;stroke:currentColor}
.tcard b{font-family:'Space Grotesk';font-size:15.5px;font-weight:600;display:block}
.tcard p{margin:6px 0 10px;font-size:12px;color:var(--soft);line-height:1.5}
.tcard .go{font-size:12px;color:var(--accent);font-weight:500;display:flex;align-items:center;gap:5px}
.tcard .go svg{width:14px;height:14px;stroke:currentColor}
.tm-foot{text-align:center;color:#fff;font-size:12px;opacity:.85;margin:18px 0 0;display:flex;align-items:center;justify-content:center;gap:6px}
.tm-foot svg{width:13px;height:13px;stroke:#fff}
.tm-foot b{font-family:'Space Mono'}
.etq{display:grid;grid-template-columns:1fr 1fr;gap:16px;align-items:start}
.zpl{width:100%;min-height:240px;border:1px solid var(--ink-line);border-radius:10px;background:#0d0f14;color:#cfe3ff;font-family:'Space Mono';font-size:11.5px;line-height:1.55;padding:12px;resize:vertical}
.zpl:focus{outline:none;border-color:var(--accent)}
.chips{display:flex;gap:6px;flex-wrap:wrap;margin-bottom:10px}
.chip-f{font-size:11.5px;padding:5px 10px;border-radius:999px;background:var(--accent-soft);color:var(--accent);border:none;cursor:pointer;font-weight:500}
.chip-f:hover{background:#dce1fd}
.lbltog{display:flex;align-items:center;gap:10px;padding:9px 0}
.lbltog+.lbltog{border-top:1px solid var(--line-2)}
.lbltog .nme{flex:1;font-size:13px}
.dlrow{display:flex;gap:8px;flex-wrap:wrap;margin-top:10px}
.badge-prev{background:#fff;border:1px solid var(--line);border-radius:12px;padding:20px;text-align:center;box-shadow:0 8px 24px rgba(0,0,0,.08)}
.bp-ev{font-size:11px;color:var(--soft);text-transform:uppercase;letter-spacing:.08em}
.bp-name{font-family:'Space Grotesk';font-weight:600;font-size:24px;margin:8px 0 4px;color:var(--text)}
.bp-lines{display:flex;flex-direction:column;gap:5px;margin:10px 0}
.bp-l{display:flex;justify-content:space-between;gap:10px;font-size:12px;color:var(--soft)}
.bp-l b{color:var(--text);font-weight:500}
.bp-qr{display:flex;justify-content:center;margin-top:12px}
.bp-qr svg{width:84px;height:84px}
.pill-ok{font-size:11px;font-weight:600;padding:4px 11px;border-radius:999px;background:var(--ok-soft);color:var(--ok);display:inline-flex;align-items:center;gap:6px}
.lbltag{font-size:10px;padding:1px 7px;border-radius:999px;background:var(--accent-soft);color:var(--accent);font-weight:600;margin-left:7px}
.spinner{width:42px;height:42px;border-radius:50%;border:3px solid var(--line);border-top-color:var(--accent);margin:0 auto 14px}
@media (prefers-reduced-motion:no-preference){.spinner{animation:spin .9s linear infinite}}
@keyframes spin{to{transform:rotate(360deg)}}
.testbox{display:flex;align-items:center;gap:12px;background:var(--canvas);border:1px solid var(--line);border-radius:12px;padding:13px 15px}
.testbox.ok{background:var(--ok-soft);border-color:transparent}
.testbox b{font-size:13.5px}
.testbox .tk{width:22px;height:22px;stroke:var(--ok);flex-shrink:0}
.spinner-sm{width:22px;height:22px;border-radius:50%;border:2.5px solid var(--line);border-top-color:var(--accent);flex-shrink:0}
@media (prefers-reduced-motion:no-preference){.spinner-sm{animation:spin .9s linear infinite}}
.kpis4{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:12px}
.flux{display:flex;align-items:flex-end;gap:14px;height:160px;padding-top:10px}
.flux .bar{flex:1;display:flex;flex-direction:column;align-items:center;gap:7px;height:100%;justify-content:flex-end}
.flux .bar i{width:100%;max-width:46px;background:var(--accent-soft);border-radius:7px 7px 0 0;transition:height .4s}
.flux .bar.peak i{background:var(--accent)}
.flux .bar span{font-size:11.5px;color:var(--soft)}
.mrow{margin-bottom:15px}
.mrow .ml{display:flex;align-items:center;justify-content:space-between;font-size:13px;margin-bottom:6px}
.mrow .ml .nm{display:flex;align-items:center;gap:8px}
.mrow .ml .nm svg{width:16px;height:16px;stroke:var(--soft)}
.mrow .ml b{font-family:'Space Grotesk'}
.mbar{height:8px;border-radius:5px;background:var(--line-2);overflow:hidden}
.mbar i{display:block;height:8px;border-radius:5px;background:var(--accent);transition:width .4s}
.ptable{display:flex;flex-direction:column}
.prow{display:grid;grid-template-columns:1fr auto auto;gap:12px;align-items:center;padding:11px 4px;border-top:1px solid var(--line-2);font-size:13px}
.prow:first-child{border-top:none}
.prow .pn{font-weight:500}
.prow .psub{color:var(--soft);font-size:12px;margin-top:1px}
.prow .ph{color:var(--soft);font-size:12px;white-space:nowrap}
.mtag{font-size:10px;padding:2px 8px;border-radius:999px;font-weight:600;white-space:nowrap}
.mtag.cpf{background:var(--accent-soft);color:var(--accent)}
.mtag.qr{background:#EAF3DE;color:#3B6D11}

.mtag.nome{background:var(--canvas);color:var(--soft)}
.mtag.email{background:var(--line-2);color:var(--soft)}
.ic-sq{width:44px;height:44px;border-radius:11px;background:var(--accent-soft);color:var(--accent);display:flex;align-items:center;justify-content:center;flex-shrink:0}
.ic-sq svg{width:22px;height:22px;stroke:currentColor}
.email-prev{border:1px solid var(--line);border-radius:12px;overflow:hidden;background:#fff}
.email-prev .eh{padding:14px 16px;border-bottom:1px solid var(--line-2);font-size:12px;color:var(--soft);line-height:1.7}
.email-prev .eh b{color:var(--text)}
.email-prev .eb{padding:18px 16px;font-size:13.5px;line-height:1.6;color:var(--text);white-space:pre-wrap}
.email-prev .eqr{text-align:center;padding:0 16px 18px}
.email-prev .eqr .q{display:inline-block;padding:10px;border:1px solid var(--line);border-radius:10px}
.email-prev .eqr .q svg{width:118px;height:118px;display:block}
.email-prev .eqr .cap{font-size:11.5px;color:var(--soft);margin:8px 0 10px}
.email-prev .ebtn{display:inline-block;background:var(--accent);color:#fff;padding:9px 16px;border-radius:8px;font-size:13px;font-weight:500}
.foot{max-width:840px;margin:22px auto 8px;display:flex;justify-content:space-between;align-items:center;gap:12px}
.foot .sp{flex:1}
.tabs{display:flex;gap:7px;flex-wrap:wrap;margin-bottom:18px}
.tabs a{font-size:13px;padding:7px 14px;border-radius:10px;color:var(--soft);text-decoration:none;border:1px solid transparent}
.tabs a:hover{background:#fff;border-color:var(--line)}
.tabs a.on{background:var(--accent-soft);color:var(--accent);font-weight:500}
.bigmenu{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}
.mcard{display:flex;flex-direction:column;gap:11px;align-items:flex-start;text-decoration:none;color:var(--text);background:#fff;border:1px solid var(--line);border-radius:var(--r-lg);padding:22px;transition:.16s}
.mcard:hover{border-color:var(--accent);box-shadow:0 8px 22px rgba(61,85,240,.10);transform:translateY(-2px)}
.mcard .mi{width:46px;height:46px;border-radius:12px;background:var(--accent-soft);color:var(--accent);display:flex;align-items:center;justify-content:center}
.mcard .mi svg{width:24px;height:24px;stroke:currentColor}
.mcard b{font-family:'Space Grotesk';font-size:16px;font-weight:600}
.mcard p{margin:0;font-size:12.5px;color:var(--soft)}
.mcard .go{margin-top:2px;font-size:12px;color:var(--accent);font-weight:500;display:flex;align-items:center;gap:5px}
.mcard .go svg{width:14px;height:14px;stroke:currentColor}
.divider{height:1px;background:var(--line);margin:14px 0}
#wp-fields{display:grid;grid-template-columns:repeat(4,1fr);gap:10px}
#wp-fields .field{margin-bottom:0;grid-column:span 4}
#wp-fields .field.w25{grid-column:span 1}
#wp-fields .field.w50{grid-column:span 2}
#wp-fields .field.w75{grid-column:span 3}
#wp-fields .field.w100{grid-column:span 4}
.lf-grid .field.w25{grid-column:span 1}
.lf-grid .field.w50{grid-column:span 2}
.lf-grid .field.w75{grid-column:span 3}
.lf-grid .field.w100{grid-column:span 4}
@media (max-width:680px){.lf-grid .field.w25,.lf-grid .field.w50,.lf-grid .field.w75,.lf-grid .field.w100{grid-column:span 2}}

/* public page */
body.public{background:var(--canvas)}
.public-wrap{max-width:560px;margin:40px auto;padding:0 20px}
.evhead{display:flex;align-items:center;gap:14px;padding:16px 18px;background:#fff;border:1px solid var(--line);border-radius:var(--r-lg);margin-bottom:14px}
.evhead .ic{width:48px;height:48px;border-radius:12px;background:var(--accent-soft);color:var(--accent);display:flex;align-items:center;justify-content:center;flex-shrink:0}
.evhead .ic svg{width:24px;height:24px;stroke:currentColor}
.evhead h2{font-family:'Space Grotesk';font-weight:600;font-size:17px;margin:0}
.evhead p{margin:3px 0 0;color:var(--soft);font-size:12.5px;display:flex;align-items:center;gap:6px;flex-wrap:wrap}
.evhead p svg{width:14px;height:14px;stroke:currentColor;vertical-align:-2px}
.ticket{max-width:340px;margin:0 auto;background:#fff;border:1px solid var(--line);border-radius:var(--r-lg);overflow:hidden}
.ticket .tt{background:var(--accent);padding:14px 18px;display:flex;align-items:center;gap:10px}
.ticket .tt .ic{width:28px;height:28px;border-radius:8px;background:#fff;color:var(--accent);display:flex;align-items:center;justify-content:center}
.ticket .tt .ic svg{width:17px;height:17px;stroke:currentColor}
.ticket .tt b{color:#fff;font-size:13.5px;font-family:'Space Grotesk';font-weight:600;display:block}
.ticket .tt span{color:rgba(255,255,255,.82);font-size:11.5px}
.ticket .body{padding:20px;display:flex;flex-direction:column;align-items:center}
.badge{margin-top:10px;font-size:11px;padding:3px 11px;border-radius:999px;background:var(--accent-soft);color:var(--accent);font-weight:600}

/* login */
.login-box{width:100%;max-width:400px;background:var(--card);border-radius:var(--r-lg);padding:32px;box-shadow:0 24px 70px rgba(0,0,0,.28)}
.login-box .logo{width:44px;height:44px;border-radius:12px;background:linear-gradient(135deg,var(--accent),#6F7FF6);display:flex;align-items:center;justify-content:center;font-family:'Space Grotesk';font-weight:700;color:#fff;font-size:16px;margin-bottom:18px}
.login-box h1{font-family:'Space Grotesk';font-weight:600;font-size:22px;margin:0 0 4px}
.login-box p{color:var(--soft);font-size:13.5px;margin:0 0 22px}
.login-box .field{margin-bottom:14px}
.login-box .btn{width:100%;justify-content:center;margin-top:6px}

@media (max-width:880px){
  .app{grid-template-columns:1fr;grid-template-areas:"top" "main"}
  .side{position:fixed;top:58px;left:0;bottom:0;width:240px;z-index:30;transform:translateX(-100%);transition:transform .22s}
  .side.open{transform:none}
  .menu-btn{display:flex}
  .scrim{position:fixed;inset:58px 0 0;background:rgba(0,0,0,.4);z-index:20;display:none}
  .scrim.show{display:block}
  .row2,.row3,.landwrap,.bg-block,.builder,.lf-grid,.tab-cards,.etq{grid-template-columns:1fr}
  .brand .sub{display:none}
  .qr-row{flex-direction:column;align-items:flex-start}
}
@media (max-width:680px){
  #wp-fields{grid-template-columns:1fr}
  #wp-fields .field, #wp-fields .field.w25, #wp-fields .field.w50, #wp-fields .field.w75, #wp-fields .field.w100{grid-column:span 1}
}
@media (prefers-reduced-motion:reduce){*{animation:none!important;transition:none!important}}
.btn:focus-visible,.nav-item:focus-visible,a:focus-visible,button:focus-visible,.sw:focus-visible,.radio:focus-visible{outline:2px solid var(--accent);outline-offset:2px}

/* extras para componentes interativos do sistema real */
.fitem .wgrp{display:flex;gap:4px;margin-left:auto;margin-right:10px}
.fitem .wbtn{border:1px solid var(--line);background:#fff;border-radius:6px;font-size:10px;padding:2px 6px;color:var(--soft);cursor:pointer;line-height:1}
.fitem .wbtn.on{background:var(--accent);border-color:var(--accent);color:#fff}
.fitem .lbl{flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.fchip .ty{color:var(--accent)}
.bz-empty{color:var(--mute);font-size:12.5px;text-align:center;padding:40px 8px;margin:auto}
.empty{color:var(--mute);font-size:12.5px;text-align:center;padding:40px 8px;margin:auto}
.sw.off{background:var(--line)}
.notice{display:flex;align-items:center;gap:10px;font-size:13.5px}
.notice.ok{color:var(--ok)}
.notice.err{color:var(--warn)}
.shake{animation:shake .35s ease-in-out}
@keyframes shake{0%,100%{transform:translateX(0)}25%{transform:translateX(-5px)}50%{transform:translateX(5px)}75%{transform:translateX(-3px)}}
.tg-err{display:none}
.tg-hint{display:block}
.hidden{display:none !important}
.center{text-align:center}
.mono{font-family:'Space Mono',monospace}
.bg-prev input[type="color"]{opacity:0;width:0;height:0;padding:0;border:0}
input[type="color"]{border:none;background:none;padding:0;width:36px;height:30px;cursor:pointer}
.tbl{width:100%;border-collapse:collapse;font-size:13px}
.tbl th{text-align:left;border-bottom:1px solid var(--line);padding:10px 8px;font-weight:600;color:var(--soft)}
.tbl td{padding:10px 8px;border-bottom:1px solid var(--line-2);vertical-align:middle}
.tbl tr:last-child td{border-bottom:none}
.pill{display:inline-flex;align-items:center;gap:6px;font-size:11px;padding:3px 10px;border-radius:999px;font-weight:600;white-space:nowrap}
.pill.ok{background:var(--ok-soft);color:var(--ok)}
.pill.warn{background:var(--warn-soft);color:var(--warn)}
.pill.accent{background:var(--accent-soft);color:var(--accent)}


/* tela de totem/check-in público (sem moldura de tablet) */
.tab-screen{min-height:100vh;display:flex;align-items:center;justify-content:center;background:#13151C;background-size:cover;background-position:center;padding:clamp(16px,4vw,40px);transition:background .3s}
.tg-card{background:#fff;border-radius:16px;padding:26px 28px;width:100%;max-width:420px;text-align:center;box-shadow:0 14px 40px rgba(0,0,0,.25)}
.tg-card-wide{max-width:520px}
.tg-card-narrow{max-width:420px}
.totem-stats{width:100%;max-width:760px;margin:14px auto 0;display:grid;grid-template-columns:repeat(3,1fr);gap:12px}

@media (max-width:760px){
  .tab-screen{padding:20px}
  .tg-card{padding:22px 20px;border-radius:14px}
}

@media (max-width:560px){
  .tab-screen{padding:16px}
  .tg-card{padding:18px 16px}
  .tg-card-wide,.tg-card-narrow{max-width:100%}
  .totem-stats{grid-template-columns:1fr}
}

/* layout do totem/check-in público */
.totem-search{display:flex;gap:8px;margin:18px 0}
.totem-search .in{flex:1;font-size:16px;padding:12px 14px}
.totem-search .btn{padding:0 16px;display:flex;align-items:center;justify-content:center}
.totem-search .btn svg{width:18px;height:18px}
.totem-methods-wrap{border-top:1px solid var(--line);padding-top:14px;margin-top:14px}
.totem-methods-wrap .muted{margin:0 0 10px;font-size:12px;text-align:center}
.totem-methods{display:grid;grid-template-columns:repeat(2,1fr);gap:8px}
.totem-methods .btn{justify-content:center}

@media (max-width:420px){
  .totem-methods{grid-template-columns:1fr}
  .totem-search .in{font-size:15px;padding:11px 12px}
  .totem-search .btn{padding:0 14px}
}

/* menu de operações do totem público */
.tab-screen-menu{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:clamp(16px,3vw,40px)}
.tab-screen-menu .tab-menu{width:100%;max-width:900px;color:#fff}
.tab-screen-menu .topline{text-align:center;margin-bottom:18px}
.tab-screen-menu .topline .tm-n{font-family:'Space Grotesk';font-weight:600;font-size:20px}
.tab-screen-menu .topline .tm-m{font-size:12px;opacity:.85;margin-top:3px}
.tab-screen-menu .tab-cards{display:flex;gap:12px;justify-content:center;flex-wrap:nowrap}
.tab-screen-menu .tcard{flex:1 1 0;min-width:140px;max-width:240px;padding:18px}
.tab-screen-menu .tm-foot{text-align:center;font-size:12px;opacity:.85;margin-top:18px;display:flex;align-items:center;justify-content:center;gap:6px}
.tab-screen-menu .tm-foot svg{width:13px;height:13px;stroke:#fff}
.tab-screen-menu .tm-foot b{font-family:'Space Mono'}

@media (max-width:760px){
  .tab-screen-menu .tab-cards{gap:10px}
  .tab-screen-menu .tcard{padding:14px;min-width:120px}
  .tab-screen-menu .tcard b{font-size:14px}
  .tab-screen-menu .tcard p{font-size:11px}
  .tab-screen-menu .topline .tm-n{font-size:18px}
}

@media (max-width:560px){
  .tab-screen-menu{padding:14px}
  .tab-screen-menu .topline{margin-bottom:14px}
  .tab-screen-menu .tcard{padding:12px;min-width:100px}
  .tab-screen-menu .tc-ic{width:36px;height:36px;margin-bottom:8px}
  .tab-screen-menu .tc-ic svg{width:18px;height:18px}
}

/* moldura de tablet para simulação no painel/terminal */
.tablet-preview{display:flex;flex-direction:column;align-items:center;gap:18px}
.tablet{position:relative;width:100%;max-width:980px;margin:0 auto;background:#111;border-radius:34px;padding:18px 18px 22px;box-shadow:0 28px 80px rgba(0,0,0,.35), inset 0 0 0 2px rgba(255,255,255,.08)}
.tablet .cam{position:absolute;top:14px;left:50%;transform:translateX(-50%);width:10px;height:10px;border-radius:50%;background:#333;box-shadow:inset 0 0 0 1px rgba(255,255,255,.12)}
.tablet iframe.tab-screen{display:block;width:100%;min-height:560px;border:0;border-radius:22px;background:#13151C}

/* barra de navegação entre estados do totem */
.preview-bar{display:flex;gap:8px;justify-content:center;max-width:980px;margin:0 auto}
.preview-bar .btn{white-space:nowrap;flex:1;justify-content:center}
.preview-bar .btn.active{box-shadow:0 0 0 2px var(--accent)}

@media (max-width:760px){
  .tablet{padding:14px 14px 18px;border-radius:26px}
  .tablet iframe.tab-screen{min-height:420px;border-radius:18px}
}
@media (max-width:480px){
  .tablet{padding:12px 12px 16px;border-radius:22px}
  .tablet .cam{width:8px;height:8px;top:11px}
  .preview-bar .btn{padding:8px 12px;font-size:12px}
}

/* tela de check-in do totem */
.tg-checkin{max-width:520px;width:100%;background:#fff;border-radius:22px;padding:32px;box-shadow:0 20px 50px rgba(0,0,0,.28)}
.tg-checkin .ch-head{text-align:center;margin-bottom:24px}
.tg-checkin .ch-head .tg-ic{margin:0 auto 14px}
.tg-checkin .ch-head .tg-ttl{font-size:22px;margin-bottom:6px}
.tg-checkin .ch-head .tg-sub{font-size:13px;margin:0}

.tg-search{position:relative;display:flex;align-items:center;background:var(--canvas);border:1px solid var(--line);border-radius:14px;padding:6px;margin-bottom:18px;transition:box-shadow .2s,border-color .2s}
.tg-search:focus-within{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft)}
.tg-search svg{position:absolute;left:16px;width:20px;height:20px;stroke:var(--soft);pointer-events:none}
.tg-search .in{flex:1;border:0;background:transparent;padding:16px 16px 16px 46px;font-size:17px;outline:none;box-shadow:none}
.tg-search .btn{height:46px;padding:0 20px;border-radius:10px;display:flex;align-items:center;justify-content:center;flex-shrink:0}

.tg-methods{display:flex;gap:8px;justify-content:center;flex-wrap:wrap;margin-bottom:4px}
.tg-methods a{display:inline-flex;align-items:center;gap:6px;padding:9px 14px;border-radius:999px;background:#fff;border:1px solid var(--line);font-size:13px;font-weight:500;color:var(--ink);text-decoration:none;transition:.15s}
.tg-methods a.on{background:var(--accent);border-color:var(--accent);color:#fff}
.tg-methods a svg{width:15px;height:15px;stroke:currentColor}

.tg-results{display:flex;flex-direction:column;gap:8px;margin:14px 0 4px}
.tg-result{width:100%;text-align:left;display:flex;align-items:center;gap:12px;padding:12px;border:1px solid var(--line);border-radius:14px;background:#fff;cursor:pointer;font:inherit;transition:border-color .15s,box-shadow .15s}
.tg-result:hover{border-color:var(--accent);box-shadow:0 4px 12px rgba(0,0,0,.08)}
.tg-result .avatar{width:42px;height:42px;border-radius:50%;background:var(--accent-soft);color:var(--accent);display:flex;align-items:center;justify-content:center;font-weight:600;font-size:15px;flex-shrink:0}
.tg-result .info{flex:1;min-width:0}
.tg-result .info strong{display:block;font-size:14px;color:var(--text)}
.tg-result .info span{display:block;font-size:12px;color:var(--soft);margin-top:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}

.tg-guest{text-align:center}
.tg-guest .avatar-big{width:72px;height:72px;border-radius:50%;background:var(--accent-soft);color:var(--accent);display:flex;align-items:center;justify-content:center;font-weight:700;font-size:24px;margin:0 auto 14px}
.tg-guest .nome{font-size:20px;font-weight:600;color:var(--text)}
.tg-guest .meta{color:var(--soft);font-size:13px;margin-top:4px}
.tg-guest .code{font-family:'Space Mono';font-size:12px;color:var(--mute);margin-top:8px}

@media (max-width:560px){
  .tg-checkin{padding:22px 18px;border-radius:18px}
  .tg-search .in{font-size:16px}
  .tg-methods a{font-size:12px;padding:8px 12px}
}
