/* ====== Korvo Studio — tokens + classes compartilhadas dos templates ====== */
:root{
  --orange:#FF4500; --void:#050505; --surface:#0D0D0D; --cream:#F5F4E7;
  --green:#00E676; --amber:#FFC107; --red:#D32F2F; --blue:#2979FF; --text2:#9a9a96;
  --mid:#2A2A2A; --light:#3F3F3F;
  --display:'Chakra Petch',sans-serif; --body:'Inter',sans-serif; --data:'JetBrains Mono',monospace;
  --grain:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='220' height='220'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.82' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.5'/%3E%3C/svg%3E");
}
*{box-sizing:border-box;margin:0;padding:0;}

/* ====== APP SHELL ====== */
html,body{height:100%;background:#16181a;color:#e9e9e6;font-family:var(--body);-webkit-font-smoothing:antialiased;}
.app{display:grid;grid-template-columns:430px 1fr;height:100vh;overflow:hidden;}

/* ---- coluna de controles ---- */
.panel{background:#1d2023;border-right:1px solid #2c2f33;overflow-y:auto;padding:24px 24px 80px;}
.panel::-webkit-scrollbar{width:10px;} .panel::-webkit-scrollbar-thumb{background:#34383d;border-radius:6px;}
.brand{display:flex;align-items:center;gap:12px;margin-bottom:6px;}
.brand img{height:30px;}
.brand .v{font-family:var(--data);font-size:10px;letter-spacing:.16em;text-transform:uppercase;color:#6f7276;border:1px solid #34383d;padding:3px 7px;}
.tagline{font-family:var(--data);font-size:11px;letter-spacing:.06em;color:#74777b;margin-bottom:22px;line-height:1.5;}

.tabs{display:flex;gap:6px;margin-bottom:22px;flex-wrap:wrap;}
.tab{flex:1;min-width:84px;font-family:var(--display);font-weight:600;font-size:12px;letter-spacing:.01em;color:#9a9da1;background:#23262a;border:1px solid #2f3236;padding:11px 6px;cursor:pointer;text-align:center;transition:.15s;}
.tab:hover{border-color:#44484d;color:#cfd1d4;}
.tab.on{background:var(--orange);border-color:var(--orange);color:#0a0a0a;}

.section{border-top:1px solid #2c2f33;padding-top:18px;margin-top:18px;}
.section:first-of-type{border-top:0;margin-top:0;padding-top:0;}
.section h3{font-family:var(--data);font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:#7e8185;margin-bottom:14px;display:flex;align-items:center;gap:8px;}
.section h3::before{content:'';width:14px;height:2px;background:var(--orange);}

label.fld{display:block;margin-bottom:14px;}
label.fld .lab{font-family:var(--data);font-size:11px;letter-spacing:.04em;color:#8a8d91;display:block;margin-bottom:6px;}
.input,.textarea,select.input{width:100%;background:#121417;border:1px solid #313539;color:#e9e9e6;font-family:var(--body);font-size:14px;padding:11px 12px;border-radius:4px;outline:none;transition:.15s;}
.input:focus,.textarea:focus{border-color:var(--orange);}
.textarea{font-family:var(--data);font-size:12.5px;line-height:1.5;resize:vertical;min-height:120px;}
.row2{display:grid;grid-template-columns:1fr 1fr;gap:10px;}
.hintline{font-family:var(--data);font-size:10.5px;color:#6b6e72;margin-top:-8px;margin-bottom:14px;line-height:1.5;}

.btn{font-family:var(--display);font-weight:600;font-size:13px;letter-spacing:.04em;padding:12px 16px;border-radius:4px;cursor:pointer;border:1px solid transparent;transition:.15s;display:inline-flex;align-items:center;justify-content:center;gap:8px;}
.btn.primary{background:var(--orange);color:#0a0a0a;width:100%;}
.btn.primary:hover{filter:brightness(1.08);}
.btn.ghost{background:#23262a;border-color:#34383d;color:#cfd1d4;}
.btn.ghost:hover{border-color:#50555a;}
.btn.block{width:100%;}

/* dropzone */
.drop{border:1.5px dashed #3a3e43;border-radius:6px;background:#121417;padding:18px;text-align:center;cursor:pointer;transition:.15s;position:relative;overflow:hidden;}
.drop:hover,.drop.over{border-color:var(--orange);background:#161a1e;}
.drop .ic{font-size:22px;}
.drop .t{font-family:var(--data);font-size:11px;letter-spacing:.04em;color:#8a8d91;margin-top:6px;line-height:1.5;}
.drop .thumb{position:absolute;inset:0;background-size:cover;background-position:center;}
.drop .thumb::after{content:'trocar';position:absolute;bottom:8px;right:8px;font-family:var(--data);font-size:10px;letter-spacing:.1em;text-transform:uppercase;color:#fff;background:rgba(0,0,0,.6);padding:4px 7px;}
.imgctrl{margin-top:8px;}
.imgctrl .lab{font-family:var(--data);font-size:10.5px;color:#7e8185;display:flex;justify-content:space-between;margin-bottom:4px;}
input[type=range]{width:100%;accent-color:var(--orange);}

.seg{display:flex;gap:6px;}
.seg .opt{flex:1;font-family:var(--data);font-size:11px;letter-spacing:.03em;color:#9a9da1;background:#23262a;border:1px solid #2f3236;padding:9px 6px;text-align:center;cursor:pointer;border-radius:4px;transition:.15s;}
.seg .opt.on{background:var(--orange);border-color:var(--orange);color:#0a0a0a;}

.swatchrow{display:flex;gap:8px;}
.swatch{width:30px;height:30px;border-radius:50%;border:2px solid #2f3236;cursor:pointer;}
.swatch.on{border-color:var(--cream);}

/* ---- coluna de preview ---- */
.canvas-wrap{position:relative;display:flex;flex-direction:column;align-items:center;justify-content:center;background:#0e1012;overflow:hidden;padding:30px;}
.canvas-wrap::before{content:'';position:absolute;inset:0;background-image:radial-gradient(#23262a 1px,transparent 1px);background-size:26px 26px;opacity:.5;}
.stagebox{position:relative;z-index:1;box-shadow:0 30px 80px -24px rgba(0,0,0,.7);}
.previewToolbar{position:absolute;top:18px;right:24px;z-index:5;display:flex;gap:10px;align-items:center;}
.fmtbadge{font-family:var(--data);font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:#8a8d91;background:#1d2023;border:1px solid #2f3236;padding:7px 11px;border-radius:4px;}
.downloadBtn{font-family:var(--display);font-weight:700;font-size:13px;letter-spacing:.04em;color:#0a0a0a;background:var(--cream);border:0;padding:9px 16px;border-radius:4px;cursor:pointer;display:inline-flex;gap:8px;align-items:center;}
.downloadBtn:hover{filter:brightness(1.05);}
.downloadBtn:disabled{opacity:.5;cursor:wait;}

/* ====== CANVAS BASE (compartilhado pelos templates) ====== */
.canvas{position:relative;overflow:hidden;background:var(--void);font-family:var(--body);transform-origin:top left;}
.k-grain{position:absolute;inset:0;background-image:var(--grain);background-size:200px;opacity:.06;pointer-events:none;z-index:9;}
.k-ph{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:0;}
.k-vig{position:absolute;inset:0;z-index:2;pointer-events:none;box-shadow:inset 0 0 300px rgba(0,0,0,.8);}
.k-logo{display:block;}
.k-data{font-family:var(--data);} .k-disp{font-family:var(--display);font-weight:700;letter-spacing:-.02em;color:var(--cream);}

/* métricas (strava) */
.k-metrics{display:grid;grid-template-columns:1fr 1fr;border:1px solid var(--mid);background:rgba(8,8,8,.62);}
.k-metric{padding:34px 36px;border-right:1px solid var(--mid);border-bottom:1px solid var(--mid);}
.k-metric:nth-child(2n){border-right:none;}
.k-metric .k{font-family:var(--data);font-size:21px;letter-spacing:.1em;text-transform:uppercase;color:var(--text2);}
.k-metric .v{font-family:var(--data);font-weight:700;font-size:74px;color:var(--cream);line-height:1;margin-top:14px;letter-spacing:-.01em;display:flex;align-items:baseline;gap:8px;}
.k-metric .v .u{font-size:32px;color:var(--text2);font-weight:500;}
.k-metric.hero .v{color:var(--orange);}

.k-acwr{border:1px solid var(--mid);background:rgba(8,8,8,.62);padding:30px 36px;}
.k-acwr .top{display:flex;align-items:baseline;justify-content:space-between;}
.k-acwr .lbl{font-family:var(--data);font-size:21px;letter-spacing:.1em;text-transform:uppercase;color:var(--text2);}
.k-acwr .zone{font-family:var(--display);font-weight:700;font-size:24px;letter-spacing:.02em;}
.k-acwr .bar{position:relative;display:flex;height:18px;margin-top:22px;overflow:hidden;}
.k-acwr .bar .s1{width:40%;background:var(--mid);} .k-acwr .bar .s2{width:25%;background:var(--green);}
.k-acwr .bar .s3{width:10%;background:var(--amber);} .k-acwr .bar .s4{width:25%;background:var(--red);}
.k-acwr .mk{position:absolute;top:-8px;width:4px;height:34px;background:var(--cream);}

/* animação (story animado): linha de scan + led pulsante — engine seta posição/opacidade inline */
.scan{position:absolute;left:0;right:0;height:150px;z-index:3;pointer-events:none;background:linear-gradient(180deg,transparent,rgba(245,244,231,.05) 48%,rgba(245,244,231,.12) 50%,rgba(245,244,231,.05) 52%,transparent);}
.led-pulse{width:13px;height:13px;border-radius:50%;background:var(--green);box-shadow:0 0 14px var(--green);}

.k-sync{display:inline-flex;align-items:center;gap:12px;font-family:var(--data);font-size:22px;letter-spacing:.08em;color:var(--green);}
.k-sync .led{width:13px;height:13px;border-radius:50%;background:var(--green);box-shadow:0 0 14px var(--green);}
.k-chip{display:inline-flex;align-items:center;gap:12px;font-family:var(--data);font-weight:500;font-size:19px;letter-spacing:.04em;color:var(--cream);border:1px solid var(--mid);background:rgba(8,8,8,.6);padding:11px 16px;}
.k-chip .k{color:var(--text2);} .k-chip .v{font-weight:700;} .k-chip .d{width:10px;height:10px;border-radius:50%;background:var(--green);}

@media (max-width:900px){ .app{grid-template-columns:1fr;grid-template-rows:auto 1fr;} .panel{max-height:46vh;} }

/* ---- carrossel: trilho de slides ---- */
.crail{display:flex;flex-wrap:wrap;gap:7px;margin-bottom:12px;}
.cslide{width:42px;height:42px;font-family:var(--data);font-size:13px;font-weight:700;color:#9a9da1;background:#23262a;border:1px solid #2f3236;border-radius:4px;cursor:pointer;transition:.15s;}
.cslide:hover{border-color:#50555a;color:#cfd1d4;}
.cslide.on{background:var(--orange);border-color:var(--orange);color:#0a0a0a;}
.cadd{width:42px;height:42px;font-size:20px;font-weight:400;color:#cfd1d4;background:#1a1d20;border:1.5px dashed #3a3e43;border-radius:4px;cursor:pointer;transition:.15s;}
.cadd:hover{border-color:var(--orange);color:var(--orange);}
.crow{display:grid;grid-template-columns:1fr 1fr auto auto;gap:6px;}
.crow .btn{padding:9px 6px;font-size:11px;}

/* ---- carrossel: nav no preview ---- */
.cnav{position:absolute;bottom:24px;left:50%;transform:translateX(-50%);z-index:6;display:flex;align-items:center;gap:14px;background:#1d2023;border:1px solid #2f3236;border-radius:40px;padding:7px 10px;box-shadow:0 10px 30px -10px rgba(0,0,0,.6);}
.cnav button{width:38px;height:38px;border-radius:50%;border:1px solid #34383d;background:#23262a;color:#cfd1d4;display:grid;place-items:center;cursor:pointer;transition:.15s;}
.cnav button:hover{border-color:var(--orange);color:var(--orange);}
.cnav button:disabled{opacity:.3;cursor:default;border-color:#34383d;color:#cfd1d4;}
.cnav-count{font-family:var(--data);font-size:13px;letter-spacing:.08em;color:#cfd1d4;min-width:54px;text-align:center;}
