@import url('https://fonts.googleapis.com/css2?family=Lexend:wght@300;400;500;600;700;800&family=Work+Sans:wght@300;400;500;600;700&display=swap');

:root{
  --bee:#FCDD00; --honey:#FDCC2C; --honey-hover:#E3C700; --honey-deep:#9A7601; --honey-50:#FFF9E6; --honey-75:#FEE697;
  --ink:#1E1E1E; --ink-2:#2A2A2A; --g100:#7D7D7D; --g50:#E9E9E9;
  --paper:#FEFEFC; --cream:#F7F0E5; --card:#FFFFFF;
  --pos:#32D583; --pos-deep:#117C43; --alert:#FFA238; --neg:#FF5E52;
  --display:'Lexend',system-ui,sans-serif; --body:'Work Sans',system-ui,sans-serif; --mono:ui-monospace,Menlo,Consolas,monospace;
  --r-sm:6px; --r-md:7px; --r-lg:12px; --r-xl:16px; --r-full:100px;
  --sh-1:0 2px 4px rgba(0,0,0,.06); --sh-2:0 4px 12px rgba(0,0,0,.10); --sh-3:0 8px 24px rgba(0,0,0,.12),0 4px 8px rgba(0,0,0,.08);
  --ease:cubic-bezier(.16,1,.3,1);
}
*{box-sizing:border-box;margin:0;padding:0}

html,body{height:100%}
body{
  font-family:var(--body); background:#0E0E10; color:var(--ink);
  display:flex; align-items:center; justify-content:center;
  overflow:hidden; -webkit-font-smoothing:antialiased;
}

/* ===== viewport scaling ===== */
#viewport{ position:fixed; inset:0; display:flex; align-items:center; justify-content:center; }
#scaler{ transform-origin:center center; }

/* ===== browser frame ===== */
.browser{ width:1480px; height:920px; background:#fff; border-radius:14px; overflow:hidden; box-shadow:0 50px 120px rgba(0,0,0,.55), 0 0 0 1px rgba(255,255,255,.06); display:flex; flex-direction:column; position:relative; }
.bw-bar{ height:48px; background:#EDEDED; border-bottom:1px solid #DADADA; display:flex; align-items:center; gap:14px; padding:0 16px; flex-shrink:0; }
.bw-dots{ display:flex; gap:8px; }
.bw-dots span{ width:13px; height:13px; border-radius:50%; }
.bw-dots span:nth-child(1){background:#FF5F57} .bw-dots span:nth-child(2){background:#FEBC2E} .bw-dots span:nth-child(3){background:#28C840}
.bw-url{ flex:1; max-width:520px; height:30px; background:#fff; border-radius:var(--r-full); display:flex; align-items:center; gap:9px; padding:0 16px; font-size:13px; color:var(--g100); border:1px solid #E0E0E0; }
.bw-url svg{ flex-shrink:0; color:var(--pos-deep); }
.bw-url b{ color:var(--ink); font-weight:600; }

/* ===== app shell ===== */
.app{ flex:1; display:flex; min-height:0; background:var(--paper); }

/* sidebar */
.side{ width:240px; background:var(--ink); color:#fff; display:flex; flex-direction:column; flex-shrink:0; }
.side-logo{ padding:22px 22px 18px; display:flex; align-items:center; gap:10px; }
.side-logo img{ height:30px; }
.nav{ flex:1; padding:8px 12px; display:flex; flex-direction:column; gap:2px; overflow-y:auto; }
.nav-sec{ font-size:11px; font-weight:700; letter-spacing:1.4px; text-transform:uppercase; color:rgba(255,255,255,.32); padding:14px 12px 6px; }
.nav-item{ display:flex; align-items:center; gap:12px; padding:10px 12px; border-radius:var(--r-md); color:rgba(255,255,255,.66); font-size:14.5px; font-weight:500; cursor:pointer; transition:all .18s var(--ease); position:relative; }
.nav-item svg{ width:19px; height:19px; flex-shrink:0; }
.nav-item:hover{ background:rgba(255,255,255,.07); color:#fff; }
.nav-item.active{ background:var(--honey); color:var(--ink); font-weight:600; }
.nav-item .badge{ margin-left:auto; font-size:11px; font-weight:700; background:rgba(255,255,255,.14); color:#fff; padding:2px 8px; border-radius:var(--r-full); }
.nav-item.active .badge{ background:rgba(0,0,0,.16); color:var(--ink); }
.side-foot{ padding:14px; border-top:1px solid rgba(255,255,255,.08); }
.side-user{ display:flex; align-items:center; gap:11px; padding:8px; border-radius:var(--r-md); }
.side-user .av{ width:36px; height:36px; border-radius:var(--r-full); background:linear-gradient(135deg,var(--honey),var(--honey-deep)); color:var(--ink); display:flex; align-items:center; justify-content:center; font-weight:700; font-size:14px; flex-shrink:0; }
.side-user .un{ font-size:13.5px; font-weight:600; color:#fff; line-height:1.2; }
.side-user .ur{ font-size:11.5px; color:rgba(255,255,255,.45); }

/* main */
.main{ flex:1; display:flex; flex-direction:column; min-width:0; }
.topbar{ height:72px; border-bottom:1px solid var(--g50); display:flex; align-items:center; gap:20px; padding:0 32px; flex-shrink:0; background:#fff; }
.topbar h1{ font-family:var(--display); font-size:24px; font-weight:800; letter-spacing:-.02em; }
.topbar .sub{ font-size:13px; color:var(--g100); margin-top:1px; }
.topbar-r{ margin-left:auto; display:flex; align-items:center; gap:12px; }
.search{ width:240px; height:40px; background:var(--cream); border-radius:var(--r-md); display:flex; align-items:center; gap:9px; padding:0 14px; color:var(--g100); font-size:13.5px; }
.icon-btn{ width:40px; height:40px; border-radius:var(--r-md); background:var(--cream); display:flex; align-items:center; justify-content:center; color:var(--ink); cursor:pointer; position:relative; transition:background .18s; }
.icon-btn:hover{ background:var(--g50); }
.icon-btn .ping{ position:absolute; top:9px; right:9px; width:8px; height:8px; border-radius:50%; background:var(--neg); border:2px solid var(--cream); }

.content{ flex:1; overflow-y:auto; padding:32px; position:relative; }
.content::-webkit-scrollbar{ width:10px } .content::-webkit-scrollbar-thumb{ background:#d8d2c6; border-radius:10px; border:3px solid var(--paper) }

/* buttons */
.btn{ height:44px; padding:0 22px; border:none; border-radius:var(--r-md); font-family:var(--body); font-size:15px; font-weight:600; cursor:pointer; display:inline-flex; align-items:center; gap:9px; transition:all .18s var(--ease); }
.btn-pri{ background:var(--honey); color:var(--ink); box-shadow:var(--sh-1); }
.btn-pri:hover{ background:var(--honey-hover); box-shadow:0 4px 14px rgba(253,204,44,.45); transform:translateY(-1px); }
.btn-ghost{ background:#fff; color:var(--ink); border:1.5px solid var(--g50); }
.btn-ghost:hover{ border-color:var(--g100); }
.btn-dark{ background:var(--ink); color:#fff; }
.btn-dark:hover{ background:var(--ink-2); }

/* screen transitions */
.screen{ display:none; animation:fadeUp .45s var(--ease); }
.screen.on{ display:block; }
@keyframes fadeUp{ from{opacity:0; transform:translateY(14px)} to{opacity:1; transform:none} }

/* ===== dashboard ===== */
.metrics{ display:grid; grid-template-columns:repeat(5,1fr); gap:16px; margin-bottom:24px; }
.metric{ background:var(--card); border:1px solid var(--g50); border-radius:var(--r-lg); padding:20px 22px; box-shadow:var(--sh-1); }
.metric .ml{ font-size:12px; font-weight:700; letter-spacing:.6px; text-transform:uppercase; color:var(--g100); }
.metric .mv{ font-family:var(--display); font-size:40px; font-weight:800; letter-spacing:-.02em; line-height:1; margin-top:10px; }
.metric .ms{ font-size:12.5px; color:var(--g100); margin-top:6px; }
.metric .mv.flash{ animation:numFlash 1s var(--ease); }
@keyframes numFlash{ 0%{color:var(--honey-deep); transform:scale(1.12)} 100%{color:var(--ink); transform:none} }

.dash-grid{ display:grid; grid-template-columns:1.6fr 1fr; gap:20px; }
.panel{ background:var(--card); border:1px solid var(--g50); border-radius:var(--r-lg); padding:22px 24px; box-shadow:var(--sh-1); }
.panel-h{ display:flex; align-items:center; justify-content:space-between; margin-bottom:16px; }
.panel-t{ font-family:var(--display); font-size:18px; font-weight:700; }
.panel-link{ font-size:13px; color:var(--honey-deep); font-weight:600; cursor:pointer; }

.dev-row{ display:flex; align-items:center; gap:14px; padding:13px 0; border-bottom:1px solid var(--g50); }
.dev-row:last-child{ border-bottom:none; }
.dot{ width:10px; height:10px; border-radius:50%; flex-shrink:0; }
.dot.on{ background:var(--pos); box-shadow:0 0 8px var(--pos); }
.dot.off{ background:var(--neg); box-shadow:0 0 8px var(--neg); }
.dev-name{ flex:1; font-size:15px; font-weight:600; }
.dev-grp{ font-size:12.5px; color:var(--g100); font-weight:400; }
.dev-meta{ font-family:var(--mono); font-size:13px; color:var(--g100); }
.dev-meta.off{ color:var(--neg); }
.dev-now{ font-size:12px; color:var(--g100); margin-top:2px; }
.dev-now b{ color:var(--honey-deep); font-weight:700; }

.store-pct{ font-family:var(--display); font-size:38px; font-weight:800; letter-spacing:-.02em; line-height:1; }
.store-bar{ height:10px; border-radius:5px; background:var(--cream); overflow:hidden; margin-top:14px; }
.store-fill{ height:100%; background:linear-gradient(90deg,var(--honey),var(--honey-deep)); border-radius:5px; transition:width .8s var(--ease); }
.chart{ display:flex; align-items:flex-end; gap:6px; height:90px; margin-top:18px; }
.chart div{ flex:1; border-radius:4px 4px 0 0; background:rgba(253,204,44,.35); transition:height .6s var(--ease); }
.chart div.hot{ background:var(--honey); }

/* ===== templates gallery ===== */
.tabs{ display:flex; gap:6px; border-bottom:1px solid var(--g50); margin-bottom:24px; }
.tab{ padding:12px 18px; font-size:15px; font-weight:600; color:var(--g100); cursor:pointer; border-bottom:2.5px solid transparent; margin-bottom:-1px; }
.tab.active{ color:var(--ink); border-color:var(--honey); }
.cat-row{ display:flex; gap:9px; flex-wrap:wrap; margin-bottom:24px; }
.chip{ padding:8px 16px; border-radius:var(--r-full); font-size:13.5px; font-weight:600; background:#fff; border:1.5px solid var(--g50); color:var(--g100); cursor:pointer; transition:all .15s; }
.chip:hover{ border-color:var(--honey); color:var(--ink); }
.chip.active{ background:var(--ink); color:#fff; border-color:var(--ink); }
.tpl-grid{ display:grid; grid-template-columns:repeat(4,1fr); gap:20px; }
.tpl{ border-radius:var(--r-lg); overflow:hidden; background:#fff; border:1px solid var(--g50); box-shadow:var(--sh-1); cursor:pointer; transition:all .2s var(--ease); position:relative; }
.tpl:hover{ transform:translateY(-4px); box-shadow:var(--sh-3); border-color:var(--honey-75); }
.tpl .thumb{ aspect-ratio:16/9; overflow:hidden; position:relative; background:var(--ink); }
.tpl .thumb img{ width:100%; height:100%; object-fit:cover; display:block; }
.tpl .badges{ position:absolute; top:10px; left:10px; display:flex; gap:6px; }
.tpl .bdg{ font-size:10.5px; font-weight:700; letter-spacing:.4px; text-transform:uppercase; padding:3px 8px; border-radius:var(--r-full); background:rgba(0,0,0,.6); color:#fff; backdrop-filter:blur(4px); }
.tpl .bdg.hot{ background:var(--honey); color:var(--ink); }
.tpl .bdg.new{ background:var(--pos); color:#063; }
.tpl-cap{ padding:14px 16px; }
.tpl-cat{ font-size:11.5px; font-weight:700; letter-spacing:.5px; text-transform:uppercase; color:var(--honey-deep); }
.tpl-name{ font-family:var(--display); font-size:17px; font-weight:700; margin-top:3px; }
.tpl-use{ position:absolute; inset:0; background:rgba(30,30,30,.55); display:flex; align-items:center; justify-content:center; opacity:0; transition:opacity .2s; }
.tpl:hover .tpl-use{ opacity:1; }
.tpl-use .btn{ pointer-events:none; }

/* ===== modal ===== */
.modal-bg{ position:absolute; inset:0; background:rgba(20,20,20,.55); backdrop-filter:blur(3px); display:none; align-items:center; justify-content:center; z-index:50; animation:fadeIn .25s; }
.modal-bg.on{ display:flex; }
@keyframes fadeIn{ from{opacity:0} to{opacity:1} }
.modal{ width:760px; background:#fff; border-radius:var(--r-xl); overflow:hidden; box-shadow:var(--sh-3); animation:pop .3s var(--ease); }
@keyframes pop{ from{transform:scale(.94); opacity:0} to{transform:scale(1); opacity:1} }
.modal-prev{ aspect-ratio:16/9; background:var(--ink); position:relative; overflow:hidden; }
.modal-prev img{ width:100%; height:100%; object-fit:cover; }
.modal-body{ padding:24px 28px; }
.modal-body h3{ font-family:var(--display); font-size:24px; font-weight:800; }
.modal-meta{ display:flex; gap:18px; margin:12px 0 20px; font-size:13.5px; color:var(--g100); }
.modal-meta b{ color:var(--ink); font-weight:600; }
.modal-foot{ display:flex; gap:12px; justify-content:flex-end; }

/* ===== editor ===== */
.editor{ display:flex; flex-direction:column; height:100%; }
.ed-toolbar{ height:56px; background:#fff; border-bottom:1px solid var(--g50); display:flex; align-items:center; gap:8px; padding:0 18px; flex-shrink:0; }
.ed-tool{ width:38px; height:38px; border-radius:var(--r-md); display:flex; align-items:center; justify-content:center; color:var(--g100); cursor:pointer; transition:all .15s; }
.ed-tool:hover{ background:var(--cream); color:var(--ink); }
.ed-tool.active{ background:var(--honey); color:var(--ink); }
.ed-div{ width:1px; height:26px; background:var(--g50); margin:0 6px; }
.ed-main{ flex:1; display:flex; min-height:0; }
.ed-left{ width:60px; background:#fff; border-right:1px solid var(--g50); display:flex; flex-direction:column; align-items:center; gap:6px; padding:14px 0; flex-shrink:0; }
.ed-stage{ flex:1; background:#E8E4DA; display:flex; align-items:center; justify-content:center; padding:32px; min-width:0; position:relative; }
.canvas{ width:760px; aspect-ratio:16/9; background:#0F1B2D; border-radius:6px; box-shadow:0 20px 50px rgba(0,0,0,.3); position:relative; overflow:hidden; }
.cv-el{ position:absolute; cursor:pointer; transition:outline .12s; outline:2px solid transparent; outline-offset:3px; }
.cv-el:hover{ outline-color:rgba(253,204,44,.55); }
.cv-el.sel{ outline-color:var(--honey); }
.cv-el[contenteditable]{ cursor:text; }
.ed-right{ width:248px; background:#fff; border-left:1px solid var(--g50); flex-shrink:0; display:flex; flex-direction:column; }
.ed-panel-h{ padding:14px 18px; font-size:12px; font-weight:700; letter-spacing:1px; text-transform:uppercase; color:var(--g100); border-bottom:1px solid var(--g50); }
.layers{ padding:8px; flex:1; overflow-y:auto; }
.layer{ display:flex; align-items:center; gap:10px; padding:9px 10px; border-radius:var(--r-md); font-size:13.5px; cursor:pointer; }
.layer:hover{ background:var(--cream); }
.layer.sel{ background:var(--honey-50); }
.layer .lr-ic{ color:var(--g100); display:flex; }
.layer .lr-name{ flex:1; font-weight:500; }
.layer .lr-eye{ color:var(--g100); }
.inspector{ border-top:1px solid var(--g50); padding:16px 18px; }
.insp-row{ margin-bottom:14px; }
.insp-row label{ font-size:12px; font-weight:600; color:var(--g100); display:block; margin-bottom:7px; }
.insp-input{ width:100%; height:38px; border:1.5px solid var(--g50); border-radius:var(--r-md); padding:0 12px; font-family:var(--body); font-size:14px; }
.insp-input:focus{ outline:none; border-color:var(--honey); }
.swatches{ display:flex; gap:8px; }
.sw{ width:34px; height:34px; border-radius:var(--r-md); cursor:pointer; border:2px solid transparent; transition:transform .12s; }
.sw:hover{ transform:scale(1.08); }
.sw.sel{ border-color:var(--ink); }
.font-row{ display:flex; gap:8px; }
.font-row select{ flex:1; height:38px; border:1.5px solid var(--g50); border-radius:var(--r-md); padding:0 10px; font-family:var(--body); font-size:14px; background:#fff; }

/* render overlay */
.render-bg{ position:absolute; inset:0; background:rgba(20,20,20,.7); backdrop-filter:blur(4px); display:none; align-items:center; justify-content:center; z-index:60; }
.render-bg.on{ display:flex; }
.render-card{ width:420px; background:#fff; border-radius:var(--r-xl); padding:36px; text-align:center; box-shadow:var(--sh-3); }
.render-card h3{ font-family:var(--display); font-size:21px; font-weight:800; margin-bottom:6px; }
.render-card p{ font-size:14px; color:var(--g100); margin-bottom:22px; }
.rbar{ height:10px; background:var(--cream); border-radius:5px; overflow:hidden; }
.rfill{ height:100%; width:0; background:linear-gradient(90deg,var(--honey),var(--honey-deep)); border-radius:5px; }
.rpct{ font-family:var(--mono); font-size:13px; color:var(--g100); margin-top:12px; }
.render-done{ width:64px; height:64px; border-radius:50%; background:var(--pos); display:flex; align-items:center; justify-content:center; margin:0 auto 18px; color:#fff; }

/* ===== programação ===== */
.sched-top{ display:flex; align-items:center; gap:14px; margin-bottom:20px; }
.sel-group{ height:42px; border:1.5px solid var(--g50); border-radius:var(--r-md); padding:0 16px; font-family:var(--body); font-size:14.5px; font-weight:600; background:#fff; display:flex; align-items:center; gap:10px; }
.sched{ background:#fff; border:1px solid var(--g50); border-radius:var(--r-lg); overflow:hidden; box-shadow:var(--sh-1); }
.sched-grid{ display:grid; grid-template-columns:72px repeat(7,1fr); }
.sg-cell{ border-right:1px solid var(--g50); border-bottom:1px solid var(--g50); padding:7px; min-height:64px; }
.sg-cell:nth-child(8n+1){ border-right:1px solid var(--g50); }
.sg-head{ background:var(--cream); font-size:13px; font-weight:700; text-transform:uppercase; letter-spacing:.6px; text-align:center; min-height:auto; padding:12px 7px; color:var(--ink); }
.sg-time{ background:var(--cream); font-size:12.5px; color:var(--g100); font-weight:600; text-align:right; padding-right:12px; display:flex; align-items:flex-start; justify-content:flex-end; padding-top:10px; }
.sg-slot{ height:100%; border-radius:var(--r-sm); border:1.5px dashed transparent; cursor:pointer; transition:all .15s; display:flex; align-items:center; justify-content:center; }
.sg-slot.empty:hover{ border-color:var(--honey); background:var(--honey-50); }
.sg-slot.empty:hover::after{ content:'+'; font-size:22px; color:var(--honey-deep); font-weight:300; }
.sg-block{ border-radius:var(--r-sm); padding:7px 9px; font-size:12.5px; font-weight:700; line-height:1.2; height:100%; display:flex; flex-direction:column; justify-content:center; overflow:hidden; }
.sg-block small{ font-size:10.5px; font-weight:600; opacity:.8; display:block; }
.sg-target{ animation:slotPulse 1.4s infinite; }
@keyframes slotPulse{ 0%,100%{ box-shadow:inset 0 0 0 2px var(--honey) } 50%{ box-shadow:inset 0 0 0 2px var(--honey-deep) } }

/* schedule modal */
.smodal{ width:440px; background:#fff; border-radius:var(--r-xl); overflow:hidden; box-shadow:var(--sh-3); animation:pop .3s var(--ease); }
.smodal-h{ padding:22px 26px 0; }
.smodal-h h3{ font-family:var(--display); font-size:20px; font-weight:800; }
.smodal-h p{ font-size:13.5px; color:var(--g100); margin-top:3px; }
.smodal-body{ padding:20px 26px; }
.opt{ display:flex; align-items:center; gap:13px; padding:13px 15px; border:1.5px solid var(--g50); border-radius:var(--r-md); cursor:pointer; margin-bottom:10px; transition:all .15s; }
.opt:hover{ border-color:var(--honey); }
.opt.sel{ border-color:var(--honey); background:var(--honey-50); }
.opt-thumb{ width:54px; aspect-ratio:16/9; border-radius:var(--r-sm); object-fit:cover; flex-shrink:0; background:var(--ink); }
.opt-name{ font-size:14.5px; font-weight:600; }
.opt-meta{ font-size:12px; color:var(--g100); }
.opt .check{ margin-left:auto; width:22px; height:22px; border-radius:50%; border:2px solid var(--g50); display:flex; align-items:center; justify-content:center; color:#fff; }
.opt.sel .check{ background:var(--honey); border-color:var(--honey); color:var(--ink); }

/* ===== publish / live ===== */
.publish-hero{ text-align:center; padding:30px 0 36px; }
.tv-wall{ display:grid; grid-template-columns:repeat(3,1fr); gap:26px; max-width:1100px; margin:0 auto; }
.tvset{ }
.tv{ background:#0a0a0a; border-radius:12px; padding:12px; box-shadow:var(--sh-3); }
.tv-scr{ border-radius:4px; overflow:hidden; aspect-ratio:16/9; position:relative; background:#0F1B2D; }
.tv-scr img{ width:100%; height:100%; object-fit:cover; display:block; }
.tv-stand{ width:90px; height:14px; background:#0a0a0a; border-radius:0 0 8px 8px; margin:0 auto; }
.tv-foot{ height:30px; width:54px; background:#1a1a1a; border-radius:0 0 5px 5px; margin:0 auto; }
.tv-cap{ text-align:center; margin-top:14px; }
.tv-cap .tn{ font-size:15px; font-weight:700; }
.tv-cap .tg{ font-size:12.5px; color:var(--g100); }
.live-tag{ position:absolute; top:10px; right:10px; display:flex; align-items:center; gap:6px; background:rgba(0,0,0,.55); padding:4px 10px; border-radius:var(--r-full); font-size:11px; font-weight:700; color:#fff; letter-spacing:.5px; backdrop-filter:blur(4px); }
.live-tag .ld{ width:7px; height:7px; border-radius:50%; background:var(--neg); animation:livePulse 1.4s infinite; }
@keyframes livePulse{ 0%,100%{opacity:1} 50%{opacity:.3} }

/* sync overlay */
.sync-bg{ position:absolute; inset:0; background:rgba(20,20,20,.72); backdrop-filter:blur(4px); display:none; flex-direction:column; align-items:center; justify-content:center; z-index:60; gap:26px; }
.sync-bg.on{ display:flex; }
.sync-ring{ width:90px; height:90px; }
.sync-ring circle{ fill:none; stroke-width:6; }
.sync-ring .bg{ stroke:rgba(255,255,255,.12); }
.sync-ring .fg{ stroke:var(--honey); stroke-linecap:round; transition:stroke-dashoffset .3s linear; }
.sync-txt{ color:#fff; font-family:var(--display); font-size:20px; font-weight:700; }
.sync-sub{ color:rgba(255,255,255,.6); font-size:14px; font-family:var(--mono); margin-top:-16px; }

/* ===== coach (self-service guide) ===== */
.coach{ position:absolute; z-index:80; pointer-events:none; max-width:300px; }
.coach.on{ animation:coachIn .35s var(--ease); }
@keyframes coachIn{ from{opacity:0; transform:translateY(8px)} to{opacity:1; transform:none} }
.coach-bubble{ background:var(--ink); color:#fff; border-radius:var(--r-lg); padding:16px 18px; box-shadow:var(--sh-3); pointer-events:auto; position:relative; }
.coach-step{ font-size:11px; font-weight:700; letter-spacing:1px; text-transform:uppercase; color:var(--honey); margin-bottom:5px; }
.coach-bubble p{ font-size:14px; line-height:1.45; color:rgba(255,255,255,.9); }
.coach-bubble .arrow{ position:absolute; width:14px; height:14px; background:var(--ink); transform:rotate(45deg); }
.coach-skip{ position:absolute; bottom:18px; right:22px; z-index:80; font-size:12.5px; color:rgba(255,255,255,.5); cursor:pointer; pointer-events:auto; }
.coach-skip:hover{ color:#fff; }

/* highlight ring around coached target */
.coach-ring{ position:absolute; z-index:70; border-radius:var(--r-lg); pointer-events:none; box-shadow:0 0 0 3px var(--honey), 0 0 0 9999px rgba(20,20,20,.45); transition:all .35s var(--ease); }
@keyframes ringPulse{ 0%,100%{box-shadow:0 0 0 3px var(--honey),0 0 0 9999px rgba(20,20,20,.45)} 50%{box-shadow:0 0 0 6px var(--honey),0 0 0 9999px rgba(20,20,20,.45)} }
.coach-ring.pulse{ animation:ringPulse 1.6s infinite; }

/* toast */
.toast{ position:absolute; bottom:24px; left:50%; transform:translateX(-50%) translateY(80px); background:var(--ink); color:#fff; padding:14px 22px; border-radius:var(--r-full); font-size:14px; font-weight:600; box-shadow:var(--sh-3); display:flex; align-items:center; gap:10px; z-index:90; opacity:0; transition:all .4s var(--ease); }
.toast.on{ transform:translateX(-50%) translateY(0); opacity:1; }
.toast .ti{ color:var(--pos); display:flex; }

/* restart pill */
.restart{ position:fixed; bottom:18px; right:18px; z-index:200; background:rgba(255,255,255,.12); color:#fff; border:1px solid rgba(255,255,255,.2); backdrop-filter:blur(8px); padding:9px 16px; border-radius:var(--r-full); font-family:var(--body); font-size:13px; font-weight:600; cursor:pointer; display:flex; align-items:center; gap:8px; transition:background .2s; }
.restart:hover{ background:rgba(255,255,255,.2); }
