:root{--bg: #f7f8fb;--surface: #ffffff;--surface-2: #f1f3f8;--line: #e6e8ef;--line-strong: #d3d7e2;--ink: #0b1220;--ink-soft: #475168;--ink-mute: #7c869b;--brand: #14b8a6;--brand-ink: #0d8c80;--brand-glow: rgba(20, 184, 166, .18);--accent: #6366f1;--accent-glow: rgba(99, 102, 241, .18);--warn: #f59e0b;--danger: #ef4444;--ok: #22c55e;--dark-bg: #0a0e1a;--dark-surface: #0f172a;--dark-surface-2: #142036;--dark-line: #1f2a44;--dark-ink: #e6ebf5;--dark-ink-soft: #98a2b8;--radius-sm: 6px;--radius: 10px;--radius-lg: 16px;--shadow-sm: 0 1px 2px rgba(11, 18, 32, .04), 0 1px 1px rgba(11, 18, 32, .06);--shadow: 0 4px 14px rgba(11, 18, 32, .06), 0 1px 2px rgba(11, 18, 32, .04);--shadow-lg: 0 12px 40px rgba(11, 18, 32, .12);--font-sans: "Inter", system-ui, -apple-system, "Segoe UI", sans-serif;--font-mono: "JetBrains Mono", ui-monospace, "SF Mono", Menlo, Monaco, Consolas, monospace}*{box-sizing:border-box}html,body{margin:0;padding:0;overflow-x:hidden}body{font-family:var(--font-sans);font-size:15px;line-height:1.5;color:var(--ink);background:var(--bg);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}a{color:var(--brand-ink);text-decoration:none}a:hover{text-decoration:underline}button{font-family:inherit;cursor:pointer}input,textarea,select{font-family:inherit}.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;height:36px;padding:0 16px;border:1px solid var(--line-strong);background:var(--surface);color:var(--ink);border-radius:5px;font-family:var(--font-sans);font-weight:500;font-size:13px;line-height:1;letter-spacing:0;white-space:nowrap;cursor:pointer;user-select:none;text-decoration:none;transition:background .12s ease,border-color .12s ease,color .12s ease,box-shadow .12s ease}.btn:hover{background:var(--surface-2);border-color:var(--ink-soft);text-decoration:none}.btn:active{background:var(--line)}.btn:disabled,.btn[disabled]{opacity:.5;cursor:not-allowed;pointer-events:none}.btn i{font-size:15px;line-height:1}.btn.sm{height:28px;padding:0 11px;font-size:12px;gap:6px;border-radius:4px}.btn.sm i{font-size:13px}.btn.lg{height:44px;padding:0 22px;font-size:14px;gap:10px}.btn.lg i{font-size:17px}.btn.icon{padding:0;width:36px}.btn.sm.icon{width:28px}.btn.lg.icon{width:44px}.btn.full{width:100%}.btn.primary{background:var(--ink);color:#fff;border-color:var(--ink)}.btn.primary:hover{background:#1a253d;border-color:#1a253d}.btn.primary:active{background:#243150}.btn.brand{background:var(--brand);color:#06302c;border-color:var(--brand);font-weight:600}.btn.brand:hover{background:#11a394;border-color:#11a394}.btn.brand:active{background:#0d8c80;border-color:#0d8c80}.btn.ghost{background:transparent;border-color:transparent;color:var(--ink-soft)}.btn.ghost:hover{background:var(--surface-2);border-color:transparent;color:var(--ink)}.btn.subtle{background:var(--surface-2);border-color:var(--surface-2);color:var(--ink-soft)}.btn.subtle:hover{background:var(--line);border-color:var(--line);color:var(--ink)}.btn.danger{background:var(--surface);border-color:#f8b4b4;color:#b1232c}.btn.danger:hover{background:#fef2f2;border-color:#ef4444}.btn.danger.solid{background:#ef4444;color:#fff;border-color:#ef4444}.btn.danger.solid:hover{background:#dc2626;border-color:#dc2626}.btn-row{display:flex;gap:8px;flex-wrap:wrap}.dual-btn{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-top:14px}.dual-btn .btn{width:100%}.btn.dark-ghost{background:#ffffff0a;border-color:#ffffff24;color:#e6ebf5}.btn.dark-ghost:hover{background:#ffffff14;border-color:#ffffff3d;color:#fff}.chip{display:inline-flex;align-items:center;padding:4px 9px;border-radius:999px;background:var(--surface-2);color:var(--ink-soft);font-size:11px;font-weight:600;letter-spacing:.04em;text-transform:uppercase}.chip.brand{background:#14b8a61f;color:var(--brand-ink)}.chip.accent{background:#6366f11f;color:var(--accent)}.chip.ok{background:#22c55e1f;color:#176c34}.chip.warn{background:#f59e0b29;color:#8a5300}.chip.danger{background:#ef444421;color:#a01818}.card{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius-lg);padding:22px;box-shadow:var(--shadow-sm)}.card.padded{padding:28px}.label{display:block;font-size:11px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--ink-soft);margin:0 0 6px}.help{font-size:12px;color:var(--ink-mute);margin-top:4px}.input,.textarea,.select{width:100%;border:1px solid var(--line-strong);background:var(--surface);border-radius:var(--radius);padding:10px 12px;font-size:14px;color:var(--ink);transition:border-color .12s ease,box-shadow .12s ease}.input:focus,.textarea:focus,.select:focus{outline:none;border-color:var(--brand);box-shadow:0 0 0 3px var(--brand-glow)}.textarea{min-height:90px;resize:vertical}.toggle{display:inline-block;position:relative;width:40px;height:22px}.toggle input{display:none}.toggle .track{position:absolute;inset:0;background:var(--line-strong);border-radius:999px;transition:background .15s ease}.toggle .track:after{content:"";position:absolute;width:18px;height:18px;left:2px;top:2px;background:#fff;border-radius:50%;box-shadow:0 1px 3px #0003;transition:transform .15s ease}.toggle input:checked+.track{background:var(--brand)}.toggle input:checked+.track:after{transform:translate(18px)}.option-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(94px,1fr));gap:8px}.option-grid.wide{grid-template-columns:repeat(auto-fill,minmax(120px,1fr))}.opt{border:1px solid var(--line-strong);background:var(--surface);border-radius:var(--radius);padding:10px 8px;font-size:12px;font-weight:600;letter-spacing:.04em;color:var(--ink);text-align:center;transition:all .12s ease}.opt:hover{border-color:var(--ink-soft)}.opt.on{background:var(--ink);color:#fff;border-color:var(--ink);box-shadow:0 4px 14px #0b12202e}.rt-editor{border:1px solid var(--line-strong);border-radius:var(--radius);overflow:hidden;background:var(--surface)}.rt-toolbar{display:flex;flex-wrap:wrap;gap:2px;padding:6px;background:var(--surface-2);border-bottom:1px solid var(--line)}.rt-btn{border:1px solid transparent;background:transparent;width:32px;height:32px;border-radius:6px;display:inline-flex;align-items:center;justify-content:center;font-size:13px;color:var(--ink-soft);transition:all .12s ease;font-family:var(--font-sans)}.rt-btn:hover{background:var(--surface);border-color:var(--line-strong);color:var(--ink)}.rt-btn.on{background:var(--ink);color:#fff;border-color:var(--ink)}.rt-btn i{font-size:15px}.rt-sep{width:1px;background:var(--line-strong);margin:4px}.rt-content{padding:14px 16px;min-height:220px;font-size:14px;line-height:1.55;color:var(--ink);outline:none}.rt-content:focus{background:#fcfdff}.rt-content h3{font-size:17px;margin:12px 0 6px;font-weight:700}.rt-content h4{font-size:14px;margin:10px 0 4px;font-weight:700;text-transform:uppercase;letter-spacing:.04em}.rt-content p{margin:0 0 8px}.rt-content ul,.rt-content ol{margin:0 0 10px;padding-left:22px}.rt-content li{margin-bottom:3px}.rt-content a{color:var(--brand-ink);text-decoration:underline}.rt-content:empty:before{content:"Empieza a escribir...";color:var(--ink-mute)}.help-rendered{font-size:14px;line-height:1.6;color:var(--ink)}.help-rendered h3{font-size:17px;margin:14px 0 6px;font-weight:700}.help-rendered h4{font-size:14px;margin:10px 0 4px;font-weight:700;text-transform:uppercase;letter-spacing:.04em}.help-rendered p{margin:0 0 10px}.help-rendered ul,.help-rendered ol{margin:0 0 12px;padding-left:22px}.help-rendered li{margin-bottom:4px}.help-rendered a{color:var(--brand-ink);text-decoration:underline}.emoji-grid{display:grid;grid-template-columns:repeat(10,1fr);gap:6px}.emoji-opt{border:1px solid var(--line-strong);background:var(--surface);border-radius:8px;font-size:16px;line-height:1;padding:8px 0;aspect-ratio:1;display:grid;place-items:center;transition:all .12s ease}.emoji-opt:hover{border-color:var(--ink-soft);transform:translateY(-1px)}.emoji-opt.on{border-color:var(--brand);box-shadow:0 0 0 2px var(--brand-glow);background:#14b8a60f}.emoji-pos{display:grid;grid-template-columns:1fr 1fr;gap:8px}.emoji-pos .opt{padding:10px}.section{border-top:1px solid var(--line);padding:18px 0}.section:first-child{border-top:0;padding-top:0}.section>.section-head{display:flex;align-items:center;justify-content:space-between;cursor:pointer;user-select:none}.section>.section-head h3{margin:0;font-size:11px;font-weight:800;letter-spacing:.12em;text-transform:uppercase;color:var(--ink)}.section>.section-head .toggle-ico{color:var(--ink-mute);transition:transform .15s ease}.section.collapsed>.section-head .toggle-ico{transform:rotate(-90deg)}.section.collapsed>.section-body{display:none}.section>.section-body{padding-top:14px;display:grid;gap:14px}.field-row{display:grid;gap:6px}.field-row.cols-2{grid-template-columns:1fr 1fr;gap:10px}.field-row.cols-2>.field-row{gap:6px}.section.advanced>.section-head h3{color:var(--ink-mute)}.section.advanced>.section-head h3:after{content:"avanzado";display:inline-block;margin-left:8px;padding:2px 6px;font-size:9px;background:var(--surface-2);color:var(--ink-mute);border-radius:3px;letter-spacing:.04em}.section .field-row .option-grid{gap:6px}.option-grid.tight{grid-template-columns:repeat(auto-fill,minmax(70px,1fr))}.app-shell{display:flex;min-height:100vh;flex-direction:column}.app-header{display:flex;align-items:center;justify-content:space-between;padding:14px 22px;background:var(--ink);color:#fff;border-bottom:1px solid #000}.app-header .logo{display:flex;align-items:center;gap:10px;font-weight:700;letter-spacing:.04em}.app-header .logo-mark{width:28px;height:28px;border-radius:7px;background:linear-gradient(135deg,var(--brand) 0%,var(--accent) 100%);display:grid;place-items:center;color:#06302c;font-weight:800;font-size:13px;box-shadow:0 0 0 1px #ffffff14,0 6px 22px var(--brand-glow)}.app-header .header-actions{display:flex;align-items:center;gap:8px}.app-header .pill{display:inline-flex;align-items:center;gap:6px;height:32px;padding:0 12px;background:#ffffff12;border:1px solid rgba(255,255,255,.1);border-radius:999px;color:#cfd6e6;font-size:12px;line-height:1}.app-header .pill .dot{width:6px;height:6px;border-radius:50%;background:var(--brand);box-shadow:0 0 8px var(--brand)}.app-header .header-btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;height:32px;padding:0 12px;background:transparent;border:1px solid rgba(255,255,255,.14);color:#e6ebf5;border-radius:5px;font-family:var(--font-sans);font-size:12px;font-weight:500;line-height:1;text-decoration:none;white-space:nowrap;cursor:pointer;transition:background .12s ease,border-color .12s ease}.app-header .header-btn i{font-size:14px}.app-header .header-btn:hover{background:#ffffff14;border-color:#ffffff38;text-decoration:none}.app-header .header-btn.primary{background:#0a0e1a;border-color:#1b2541}.app-header .header-btn.icon{padding:0;width:32px}.header-menu-wrap{position:relative}.header-menu{position:absolute;top:calc(100% + 6px);right:0;min-width:200px;background:var(--surface);border:1px solid var(--line);border-radius:8px;box-shadow:var(--shadow-lg);padding:6px;opacity:0;transform:translateY(-4px);pointer-events:none;transition:opacity .12s ease,transform .12s ease;z-index:35}.header-menu.on{opacity:1;transform:translateY(0);pointer-events:auto}.header-menu button{display:flex;align-items:center;gap:10px;width:100%;padding:9px 12px;border:0;background:transparent;color:var(--ink);border-radius:5px;font-size:13px;font-weight:500;cursor:pointer;text-align:left;transition:background .1s ease}.header-menu button i{font-size:15px;color:var(--ink-soft)}.header-menu button:hover{background:var(--surface-2)}.app-header .header-btn.admin-shortcut{background:var(--brand);border-color:var(--brand);color:#06302c;font-weight:600;width:32px;padding:0}.app-header .header-btn.admin-shortcut:hover{background:#11a394;border-color:#11a394}.app-header .header-btn.has-dot{position:relative}.app-header .header-btn .red-dot{position:absolute;top:6px;right:6px;width:8px;height:8px;background:#ef4444;border-radius:50%;border:2px solid var(--ink);box-shadow:0 0 #ef444499;animation:red-dot-pulse 2s infinite}@keyframes red-dot-pulse{0%{box-shadow:0 0 #ef444499}70%{box-shadow:0 0 0 6px #ef444400}to{box-shadow:0 0 #ef444400}}.novedad-item{padding:18px 0;border-bottom:1px solid var(--line)}.novedad-item:first-child{padding-top:0}.novedad-item:last-child{border-bottom:0}.novedad-meta{display:flex;align-items:center;gap:10px;margin-bottom:8px}.novedad-date{font-size:12px;color:var(--ink-mute)}.novedad-title{margin:0 0 10px;font-size:17px;font-weight:700}.novedad-body{font-size:14px;line-height:1.55}.novedad-body h4{margin:12px 0 6px;font-size:13px;font-weight:700;letter-spacing:.04em;text-transform:uppercase;color:var(--ink)}.novedad-body ul,.novedad-body ol{margin:0 0 10px;padding-left:22px}.novedad-body li{margin-bottom:4px}.novedad-body p{margin:0 0 8px}.novedad-body b{color:var(--ink)}.app-header .avatar-dot{width:32px;height:32px;border-radius:50%;background:linear-gradient(135deg,var(--brand),var(--accent));display:grid;place-items:center;color:#06302c;font-weight:700}.app-body{display:grid;grid-template-columns:minmax(420px,540px) 1fr;flex:1}.app-panel{background:var(--surface);border-right:1px solid var(--line);padding:22px;overflow-y:auto;height:calc(100vh - 56px)}.app-panel h2{font-size:16px;margin:0 0 4px}.app-panel .sub{font-size:12px;color:var(--ink-mute);margin:0 0 18px}.app-canvas{position:relative;background:radial-gradient(circle at 20% 20%,rgba(20,184,166,.1),transparent 45%),radial-gradient(circle at 80% 80%,rgba(99,102,241,.08),transparent 45%),var(--bg);padding:28px;height:calc(100vh - 56px);overflow-y:auto;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:18px}.preview-stack{width:100%;max-width:720px;display:flex;flex-direction:column;align-items:center;gap:14px}.preview-label{font-size:11px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:var(--ink-mute)}.preview-box{width:100%;background:linear-gradient(180deg,#fff,#fafbff);border:1px solid var(--line);border-radius:var(--radius-lg);padding:36px 28px;position:relative;box-shadow:var(--shadow);overflow:hidden}.preview-box:before{content:"";position:absolute;inset:0;background:radial-gradient(circle at 50% 0%,var(--brand-glow),transparent 50%);opacity:.35;pointer-events:none}.preview-text{font-family:var(--font-mono);font-size:17px;text-align:center;color:var(--ink);word-break:break-all;position:relative;z-index:1}.preview-text.placeholder{color:var(--ink-mute);font-size:14px}.preview-actions{display:flex;gap:8px;flex-wrap:wrap;justify-content:center;width:100%;max-width:720px}.preview-actions .btn{min-width:0}.preview-actions .btn.primary,.preview-actions .btn:not(.ghost):not(.icon){min-width:160px}.preview-meta{font-size:12px;color:var(--ink-mute);display:flex;gap:14px;flex-wrap:wrap;justify-content:center}.app-foot{position:absolute;bottom:14px;left:50%;transform:translate(-50%);font-size:11px;color:var(--ink-mute);display:flex;align-items:center;gap:8px;white-space:nowrap}.app-foot a{color:var(--ink-mute);text-decoration:none}.app-foot a:hover{color:var(--brand-ink);text-decoration:underline}.app-foot .dot-sep{opacity:.5}.length-meter{display:flex;align-items:center;gap:10px;width:100%;max-width:720px;font-size:12px;color:var(--ink-mute)}.length-bar{flex:1;height:4px;background:var(--line);border-radius:999px;overflow:hidden}.length-fill{display:block;height:100%;width:0%;transition:width .15s ease,background .15s ease;background:var(--brand)}.length-meter.warn .length-fill{background:var(--warn)}.length-meter.danger .length-fill{background:var(--danger)}.length-text{font-family:var(--font-mono);font-size:11px}.length-meter.warn .length-text{color:#8a5300}.length-meter.danger .length-text{color:var(--danger);font-weight:700}.preview-meta span:before{content:"\b7";margin-right:14px;color:var(--line-strong)}.preview-meta span:first-child:before{content:"";margin-right:0}.tabs{display:grid;grid-template-columns:repeat(3,1fr);background:var(--surface-2);border-radius:12px;padding:4px;gap:4px;border:1px solid var(--line)}.tabs button{border:none;background:transparent;padding:10px;font-size:12px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--ink-soft);border-radius:8px;transition:all .12s ease}.tabs button.on{background:var(--surface);color:var(--ink);box-shadow:var(--shadow-sm)}.sep-row{display:grid;grid-template-columns:repeat(7,1fr);gap:8px}.sep-row .opt{font-family:var(--font-mono);padding:10px 0}.preset-item{padding:14px;border:1px solid var(--line);border-radius:var(--radius);margin-bottom:10px;background:var(--surface)}.preset-item:hover{border-color:var(--line-strong)}.preset-head{display:flex;align-items:center;gap:8px;margin-bottom:8px;flex-wrap:wrap}.preset-name{font-weight:600;font-size:13px;color:var(--ink)}.preset-preview{font-family:var(--font-mono);font-size:12px;color:var(--ink-soft);background:var(--surface-2);padding:8px 10px;border-radius:var(--radius-sm);word-break:break-all;margin-bottom:10px;min-height:20px;line-height:1.4}.preset-actions{display:flex;gap:6px}.preset-actions .btn{flex:0 0 auto}.preset-actions .btn.primary{flex:1}.ai-banner{display:flex;gap:12px;align-items:flex-start;background:linear-gradient(135deg,#6366f114,#14b8a614);border:1px solid rgba(99,102,241,.18);border-radius:var(--radius);padding:12px 14px;margin-bottom:16px}.ai-banner .ai-ico{width:30px;height:30px;border-radius:8px;background:linear-gradient(135deg,var(--accent),var(--brand));display:grid;place-items:center;color:#fff;flex-shrink:0}.ai-banner h4{margin:0;font-size:13px}.ai-banner p{margin:2px 0 8px;font-size:12px;color:var(--ink-soft)}.drawer-bg{position:fixed;inset:0;background:#0b122066;backdrop-filter:blur(4px);z-index:50;opacity:0;pointer-events:none;transition:opacity .15s ease}.drawer-bg.on{opacity:1;pointer-events:auto}.drawer{position:fixed;top:0;right:0;bottom:0;width:min(520px,100vw);background:var(--surface);z-index:51;transform:translate(100%);transition:transform .18s ease,box-shadow .18s ease;display:flex;flex-direction:column;box-shadow:none}.drawer.on{transform:translate(0);box-shadow:-20px 0 40px #00000026}.drawer-head{display:flex;align-items:center;justify-content:space-between;padding:18px 22px;border-bottom:1px solid var(--line)}.drawer-head h3{margin:0;font-size:16px}.drawer-head .sub{font-size:12px;color:var(--ink-mute);margin:0}.drawer-body{flex:1;overflow-y:auto;padding:18px 22px}.drawer-foot{padding:14px 22px;border-top:1px solid var(--line);display:flex;justify-content:flex-end;gap:8px}.modal-bg{position:fixed;inset:0;background:#0b122099;z-index:60;display:none;align-items:center;justify-content:center;padding:20px}.modal-bg.on{display:flex}.modal{background:var(--surface);border-radius:var(--radius-lg);max-width:460px;width:100%;padding:28px;box-shadow:var(--shadow-lg)}.modal h3{margin:0 0 6px;font-size:18px}.modal p{color:var(--ink-soft);font-size:14px}.history-item{padding:14px;border:1px solid var(--line);border-radius:var(--radius);margin-bottom:10px;background:var(--surface)}.history-item:hover{border-color:var(--line-strong)}.history-item .row1{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px}.history-item .name{font-family:var(--font-mono);font-size:13px;color:var(--ink);word-break:break-all}.history-item .actions{display:none;gap:6px;margin-top:10px}.history-item.expanded .actions{display:flex}.history-filter-row{display:flex;gap:6px;margin-bottom:14px;flex-wrap:wrap}.history-filter-row .chip{cursor:pointer;padding:6px 12px}.history-filter-row .chip.on{background:var(--ink);color:#fff}.toast{position:fixed;bottom:24px;left:50%;transform:translate(-50%) translateY(20px);background:var(--ink);color:#fff;padding:10px 16px;border-radius:999px;font-size:13px;font-weight:500;box-shadow:var(--shadow-lg);z-index:200;opacity:0;pointer-events:none;transition:all .18s ease}.toast.on{opacity:1;transform:translate(-50%) translateY(0)}.home-nav{display:flex;align-items:center;justify-content:space-between;padding:18px 32px;position:sticky;top:0;z-index:30;background:#0a0e1ac7;backdrop-filter:blur(12px);border-bottom:1px solid rgba(255,255,255,.06)}.home-nav .nav-links{display:flex;gap:24px;align-items:center}.home-nav .nav-links a{color:#b8c1d9;font-size:14px}.home-nav .nav-links a:hover{color:#fff;text-decoration:none}.home{background:var(--dark-bg);color:var(--dark-ink);min-height:100vh}.hero{position:relative;padding:80px 32px 100px;overflow:hidden}.hero:before{content:"";position:absolute;inset:0;background:radial-gradient(circle at 18% 30%,rgba(20,184,166,.18),transparent 40%),radial-gradient(circle at 82% 75%,rgba(99,102,241,.14),transparent 40%);pointer-events:none}.hero-inner{max-width:1100px;margin:0 auto;position:relative;z-index:1;text-align:center}.hero .eyebrow{display:inline-flex;align-items:center;gap:8px;padding:6px 14px;border-radius:999px;background:#14b8a61a;border:1px solid rgba(20,184,166,.3);color:var(--brand);font-size:12px;font-weight:600;letter-spacing:.06em;margin-bottom:22px}.hero h1{font-size:clamp(36px,5.5vw,60px);line-height:1.05;margin:0 0 16px;letter-spacing:-.02em;font-weight:700}.hero h1 .grad{background:linear-gradient(135deg,var(--brand) 0%,var(--accent) 100%);-webkit-background-clip:text;background-clip:text;color:transparent}.hero p.lead{font-size:clamp(15px,1.4vw,18px);color:#b0bbd6;max-width:680px;margin:0 auto 30px}.hero-ctas{display:flex;gap:12px;justify-content:center;flex-wrap:wrap}.hero-social{margin-top:22px;font-size:13px;color:#98a2b8;display:inline-flex;align-items:center;gap:6px;justify-content:center}.dot-live{display:inline-block;width:8px;height:8px;background:#22c55e;border-radius:50%;margin-right:4px;box-shadow:0 0 #22c55eb3;animation:dot-pulse 2s infinite}@keyframes dot-pulse{0%{box-shadow:0 0 #22c55e80}70%{box-shadow:0 0 0 8px #22c55e00}to{box-shadow:0 0 #22c55e00}}.faq-list{display:flex;flex-direction:column;gap:8px;margin-top:20px}.faq-item{background:#0f172a80;border:1px solid rgba(255,255,255,.06);border-radius:12px;overflow:hidden;transition:border-color .15s ease}.faq-item:hover{border-color:#14b8a640}.faq-item[open]{border-color:#14b8a659;background:#14b8a60a}.faq-item summary{padding:18px 22px;font-size:16px;font-weight:600;color:#e6ebf5;cursor:pointer;list-style:none;position:relative;display:flex;align-items:center;gap:12px}.faq-item summary::-webkit-details-marker{display:none}.faq-item summary:after{content:"+";margin-left:auto;font-size:22px;font-weight:400;color:var(--brand);transition:transform .2s ease;line-height:1}.faq-item[open] summary:after{content:"\2212"}.faq-item p{margin:0;padding:0 22px 18px;color:#98a2b8;font-size:14px;line-height:1.6}.faq-item p b{color:#cfd6e6}.sticky-cta{position:fixed;bottom:16px;left:50%;transform:translate(-50%) translateY(150%);background:#0a0e1aeb;backdrop-filter:blur(14px);border:1px solid rgba(20,184,166,.28);border-radius:999px;padding:8px 8px 8px 18px;display:flex;align-items:center;gap:14px;z-index:40;box-shadow:0 18px 50px #0006;transition:transform .25s ease,opacity .2s ease;opacity:0;pointer-events:none;max-width:calc(100vw - 32px)}.sticky-cta.on{transform:translate(-50%) translateY(0);opacity:1;pointer-events:auto}.sticky-cta-text{font-size:13px;color:#cfd6e6;font-weight:500;white-space:nowrap}@media (max-width: 600px){.sticky-cta-text{display:none}}.reveal{opacity:0;transform:translateY(18px);transition:opacity .55s ease,transform .55s ease;will-change:opacity,transform}.reveal.in-view{opacity:1;transform:translateY(0)}.feature.reveal{transition-delay:0s}.feature.reveal:nth-child(2){transition-delay:.06s}.feature.reveal:nth-child(3){transition-delay:.12s}.feature.reveal:nth-child(4){transition-delay:.18s}.feature.reveal:nth-child(5){transition-delay:.24s}.feature.reveal:nth-child(6){transition-delay:.3s}.step.reveal:nth-child(2){transition-delay:.08s}.step.reveal:nth-child(3){transition-delay:.16s}@media (prefers-reduced-motion: reduce){.reveal{opacity:1;transform:none;transition:none}.dot-live{animation:none}}.hero-demo{margin:60px auto 0;max-width:880px;position:relative;z-index:1}.hero-demo .window{background:#0f172ab3;border:1px solid rgba(255,255,255,.08);border-radius:14px;overflow:hidden;backdrop-filter:blur(10px);box-shadow:0 30px 80px #00000080}.hero-demo .titlebar{display:flex;align-items:center;gap:8px;padding:11px 14px;border-bottom:1px solid rgba(255,255,255,.06);background:#0003}.hero-demo .titlebar .dot{width:11px;height:11px;border-radius:50%}.hero-demo .titlebar .dot.r{background:#ff5f57}.hero-demo .titlebar .dot.y{background:#febc2e}.hero-demo .titlebar .dot.g{background:#28c840}.hero-demo .titlebar .url{margin-left:auto;font-family:var(--font-mono);font-size:11px;color:#6b7896}.hero-demo .demo-body{padding:28px 22px;font-family:var(--font-mono);font-size:14px;line-height:2}.demo-line{color:#6b7896}.demo-line .k{color:var(--brand)}.demo-line .v{color:#e0e6f5}.demo-line .out{color:var(--brand);font-size:17px;display:block;margin-top:14px;padding-top:14px;border-top:1px dashed rgba(255,255,255,.08);word-break:break-all}.demo-app{display:grid;grid-template-columns:320px 1fr;gap:0;min-height:420px}.demo-side{padding:22px 20px;border-right:1px solid rgba(255,255,255,.06);background:#0f172a66;display:flex;flex-direction:column;gap:16px}.demo-section{display:flex;flex-direction:column;gap:7px}.demo-label{font-size:9px;font-weight:700;letter-spacing:.12em;color:#6b7896;text-transform:uppercase}.demo-tabs{display:grid;grid-template-columns:repeat(3,1fr);gap:4px;background:#0000004d;padding:3px;border-radius:7px}.demo-tab{padding:6px;font-size:10px;font-weight:700;letter-spacing:.06em;color:#6b7896;text-align:center;border-radius:5px;transition:all .3s ease}.demo-tab.on{background:#ffffff0f;color:#e6ebf5}.demo-input{padding:9px 10px;background:#0000004d;border:1px solid rgba(255,255,255,.08);border-radius:6px;font-family:var(--font-mono);font-size:12px;color:#e6ebf5;min-height:36px;display:flex;align-items:center}.demo-cursor{display:inline-block;margin-left:2px;color:var(--brand);animation:demo-blink 1s infinite}@keyframes demo-blink{50%{opacity:0}}.demo-opts{display:flex;flex-wrap:wrap;gap:5px}.demo-opt{padding:6px 10px;font-size:10px;font-weight:700;letter-spacing:.04em;background:#ffffff0a;border:1px solid rgba(255,255,255,.06);color:#b0bbd6;border-radius:5px;transition:all .3s ease}.demo-opt.on{background:#14b8a62e;border-color:var(--brand);color:var(--brand);box-shadow:0 0 12px #14b8a64d}.demo-preview{padding:30px 24px;display:flex;flex-direction:column;gap:14px;justify-content:center;align-items:center;text-align:center}.demo-preview-label{font-size:9px;font-weight:700;letter-spacing:.14em;color:#6b7896;text-transform:uppercase}.demo-preview-box{width:100%;background:#0000004d;border:1px solid rgba(20,184,166,.18);border-radius:10px;padding:22px 18px;min-height:80px;display:flex;align-items:center;justify-content:center;position:relative;overflow:hidden}.demo-preview-box:before{content:"";position:absolute;inset:0;background:radial-gradient(circle at 50% 0%,rgba(20,184,166,.15),transparent 60%);pointer-events:none}.demo-nombre{font-family:var(--font-mono);font-size:13px;color:var(--brand);word-break:break-all;position:relative;z-index:1;line-height:1.6}.demo-nombre.placeholder{color:#6b7896;font-family:var(--font-sans);font-size:12px}.demo-preview-meta{font-size:10px;color:#6b7896}@media (max-width: 720px){.demo-app{grid-template-columns:1fr;min-height:auto}.demo-side{border-right:0;border-bottom:1px solid rgba(255,255,255,.06)}}.section-block{padding:80px 32px;position:relative}.section-block .inner{max-width:1100px;margin:0 auto}.section-block h2{font-size:clamp(26px,3vw,36px);text-align:center;margin:0 0 14px;letter-spacing:-.01em}.section-block p.sub{text-align:center;color:#98a2b8;margin:0 auto 50px;max-width:640px;font-size:16px}.feature-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}@media (max-width: 880px){.feature-grid{grid-template-columns:repeat(2,1fr)}}@media (max-width: 560px){.feature-grid{grid-template-columns:1fr}}.feature{background:#0f172a80;border:1px solid rgba(255,255,255,.06);border-radius:14px;padding:28px 24px;transition:transform .15s ease,border-color .15s ease}.feature:hover{transform:translateY(-3px);border-color:#14b8a64d}.feature .ico{width:40px;height:40px;border-radius:10px;background:linear-gradient(135deg,#14b8a629,#6366f129);display:grid;place-items:center;color:var(--brand);font-size:20px;margin-bottom:16px;border:1px solid rgba(20,184,166,.2)}.feature h3{margin:0 0 6px;font-size:16px;color:#e6ebf5}.feature p{margin:0;color:#98a2b8;font-size:14px;line-height:1.55}.steps{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:20px;counter-reset:stepnum}.step{position:relative;padding-left:20px}.step:before{counter-increment:stepnum;content:counter(stepnum,decimal-leading-zero);font-family:var(--font-mono);font-size:13px;color:var(--brand);position:absolute;left:0;top:4px;font-weight:600}.step h3{margin:0 0 8px;font-size:17px;color:#e6ebf5}.step p{margin:0;color:#98a2b8;font-size:14px}.example-list{display:grid;gap:10px;font-family:var(--font-mono);font-size:13px}.example-list .ex{display:flex;align-items:center;gap:14px;background:#0f172a99;border:1px solid rgba(255,255,255,.06);padding:14px 18px;border-radius:10px}.example-list .ex .kind{font-family:var(--font-sans);font-size:10px;font-weight:700;letter-spacing:.08em;background:#14b8a626;color:var(--brand);padding:4px 8px;border-radius:4px;flex-shrink:0}.example-list .ex .name{color:#e6ebf5;word-break:break-all}.cta-block{background:linear-gradient(135deg,#14b8a614,#6366f114);border:1px solid rgba(20,184,166,.15);border-radius:20px;padding:60px 30px;text-align:center;max-width:800px;margin:0 auto}.cta-block h2{margin:0 0 12px;font-size:clamp(24px,3vw,32px)}.cta-block p{color:#b0bbd6;margin:0 auto 26px;max-width:480px}.footer{padding:36px 32px;border-top:1px solid rgba(255,255,255,.06);text-align:center;color:#6b7896;font-size:13px}.footer a{color:#98a2b8}.legal-page{padding:60px 24px 100px;color:#cfd6e6;min-height:70vh;position:relative}.legal-page:before{content:"";position:absolute;top:0;left:0;right:0;height:320px;background:radial-gradient(circle at 50% 0%,rgba(20,184,166,.1),transparent 60%);pointer-events:none;z-index:0}.legal-grid{display:grid;grid-template-columns:220px 1fr;gap:60px;max-width:1080px;margin:0 auto;position:relative;z-index:1}@media (max-width: 880px){.legal-grid{grid-template-columns:1fr;gap:30px}}.legal-toc{position:sticky;top:100px;align-self:start;font-size:13px}.legal-toc-title{font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:#6b7896;margin:0 0 12px;font-weight:700}.legal-toc ol{list-style:none;margin:0;padding:0;counter-reset:tocidx}.legal-toc li{margin-bottom:10px;position:relative;padding-left:22px;counter-increment:tocidx}.legal-toc li:before{content:counter(tocidx,decimal-leading-zero);position:absolute;left:0;top:2px;font-family:var(--font-mono);font-size:10px;color:var(--brand);font-weight:600}.legal-toc a{color:#98a2b8;text-decoration:none;transition:color .12s ease;line-height:1.4;display:inline-block}.legal-toc a:hover{color:#fff}@media (max-width: 880px){.legal-toc{position:static;padding:16px 20px;background:#0f172a80;border:1px solid rgba(255,255,255,.06);border-radius:12px}}.legal-content{min-width:0}.legal-back{margin:0 0 24px;font-size:13px}.legal-back a{color:#98a2b8;text-decoration:none;display:inline-flex;align-items:center;gap:6px;padding:6px 12px;border:1px solid rgba(255,255,255,.08);border-radius:999px;background:#ffffff05;transition:all .12s ease}.legal-back a:hover{color:#fff;border-color:#fff3;background:#ffffff0a}.legal-page h1{font-size:clamp(32px,4.5vw,44px);font-weight:700;margin:0 0 10px;letter-spacing:-.02em;color:#fff;line-height:1.1}.legal-updated{font-size:11px;color:#6b7896;margin:0 0 36px;text-transform:uppercase;letter-spacing:.12em;font-weight:600}.legal-callout{background:linear-gradient(135deg,#14b8a60f,#6366f10f);border:1px solid rgba(20,184,166,.18);border-radius:14px;padding:22px 24px;margin:0 0 40px;display:flex;gap:16px;align-items:flex-start}.legal-callout-ico{width:36px;height:36px;border-radius:10px;background:#14b8a624;color:var(--brand);display:grid;place-items:center;font-size:18px;flex-shrink:0}.legal-callout-title{font-size:14px;font-weight:700;color:#fff;margin:0 0 4px}.legal-callout-text{font-size:13px;color:#b0bbd6;line-height:1.55;margin:0}.legal-page h2{font-size:22px;margin:44px 0 14px;color:#fff;font-weight:700;letter-spacing:-.01em;scroll-margin-top:100px}.legal-page h2:first-of-type{margin-top:0}.legal-page h3{font-size:15px;margin:24px 0 8px;color:#e6ebf5;font-weight:600;letter-spacing:-.005em}.legal-page p{font-size:15px;line-height:1.75;margin:0 0 14px;color:#b0bbd6}.legal-page b{color:#f1f5fb;font-weight:600}.legal-page ul{margin:0 0 18px;padding-left:0;list-style:none}.legal-page li{font-size:15px;line-height:1.7;margin-bottom:10px;color:#b0bbd6;position:relative;padding-left:22px}.legal-page li:before{content:"";position:absolute;left:6px;top:11px;width:6px;height:6px;border-radius:50%;background:var(--brand);opacity:.7}.legal-page a{color:var(--brand);text-decoration:none;border-bottom:1px solid rgba(20,184,166,.3);transition:border-color .12s ease}.legal-page a:hover{border-bottom-color:var(--brand)}.legal-page code{background:#ffffff0f;padding:2px 6px;border-radius:4px;font-family:var(--font-mono);font-size:12px;color:#cfd6e6}.legal-section{padding-bottom:6px}.legal-contact-card{margin-top:50px;padding:24px 26px;background:#0f172a66;border:1px solid rgba(255,255,255,.06);border-radius:14px}.legal-contact-card h3{margin:0 0 6px;font-size:16px}.legal-contact-card p{margin:0;font-size:14px}.legal-footer-note{margin-top:40px;padding:20px 0;border-top:1px solid rgba(255,255,255,.06);font-size:13px;color:#6b7896;display:flex;gap:14px;flex-wrap:wrap}.legal-footer-note a{color:#98a2b8;border:none}.legal-footer-note a:hover{color:var(--brand)}@media (max-width: 860px){.app-body{grid-template-columns:1fr}.app-panel{height:auto;border-right:none;border-bottom:1px solid var(--line)}.app-canvas{height:auto;min-height:60vh}.home-nav{padding:14px 18px;flex-wrap:nowrap;gap:10px}.home-nav .nav-links,.home-nav .home-brand-text{display:none}.home-nav .btn.brand{padding:0 12px;height:32px;font-size:12px}.hero{padding:50px 18px 60px}.section-block{padding:50px 18px}}@media (max-width: 720px){.app-header{padding:10px 12px;gap:6px}.app-header .logo .logo-text{display:none}.app-header .header-actions{gap:6px}.app-header .pill .pill-text{display:none}.app-header .pill{padding:0 8px}.app-header .header-btn .btn-text{display:none}.app-header .header-btn{width:32px;padding:0;gap:0}.app-header .header-btn.has-dot .red-dot{top:4px;right:4px}.app-header .header-btn i{font-size:15px}}@media (max-width: 380px){.app-header{padding:10px 8px;gap:4px}.app-header .header-actions{gap:4px}.app-header .pill{display:none}}.admin-shell{display:grid;grid-template-columns:240px 1fr;min-height:100vh}.admin-mobile-bar{display:none;background:var(--ink);color:#fff;padding:12px 14px;align-items:center;justify-content:space-between;position:sticky;top:0;z-index:20}.admin-burger{background:transparent;border:1px solid rgba(255,255,255,.14);color:#fff;width:36px;height:36px;border-radius:6px;display:grid;place-items:center;font-size:18px;cursor:pointer}.admin-burger:hover{background:#ffffff0f}.admin-side-backdrop{display:none;position:fixed;inset:0;background:#0b122080;z-index:49;opacity:0;transition:opacity .15s ease}.admin-side-backdrop.on{display:block;opacity:1}@media (max-width: 860px){.admin-shell{grid-template-columns:1fr;min-height:100vh}.admin-mobile-bar{display:flex}.admin-side{position:fixed;top:0;left:0;bottom:0;width:260px;z-index:50;transform:translate(-100%);transition:transform .2s ease;box-shadow:8px 0 24px #0000004d}.admin-side.open{transform:translate(0)}.admin-main{height:auto;padding:18px 16px}.admin-head{gap:8px}.admin-head h1{font-size:18px}.admin-head>div:last-child{flex-wrap:wrap;gap:6px}.range-tabs{flex-wrap:wrap}.hub-kpi-val{font-size:28px}.hub-kpi{padding:14px 18px}.hub-card-body{padding:14px;overflow-x:auto}.hub-card-head{padding:14px 16px}.hub-table th,.hub-table td{padding:8px;font-size:12px}.hub-table th{font-size:10px;letter-spacing:.04em}.funnel-head{grid-template-columns:1fr 56px 80px;font-size:10px;padding-bottom:8px}.funnel-row{grid-template-columns:1fr 56px 80px;padding:10px 0;gap:8px}.funnel-label{width:70px;font-size:11px}.funnel-bar{height:26px}.funnel-bar-fill{padding-right:8px;font-size:11px}.funnel-count{font-size:13px}.funnel-rate{font-size:12px}.table th,.table td{padding:10px 12px;font-size:12px}.admin-section{padding:16px}.field-grid.cols-2{grid-template-columns:1fr;gap:12px}.dual-btn{grid-template-columns:1fr}.sug-card .head-row{flex-direction:column;align-items:stretch;gap:10px}.sug-card .status-quick{width:100%;padding:8px 10px}.sug-card .actions{flex-wrap:wrap;row-gap:8px}.sug-card .actions .spacer{display:none}.sug-card .actions .btn{flex:1;min-width:0}.sug-card .actions .meta{font-size:11px;width:100%;margin:0!important}.sug-card .actions .meta+.meta{margin-left:0!important}.admin-main .table{display:block;overflow-x:auto;white-space:nowrap;max-width:100%}.admin-main .table thead,.admin-main .table tbody{display:table;width:max-content;min-width:100%}.admin-main .table th,.admin-main .table td{padding:10px 12px}}.changelog-card{padding:16px 20px!important}.changelog-row{display:flex;align-items:flex-start;justify-content:space-between;gap:14px}.changelog-content{flex:1;min-width:0}.changelog-chips{display:flex;gap:8px;align-items:center;margin-bottom:8px;flex-wrap:wrap}.changelog-date{font-size:12px;color:var(--ink-mute)}.changelog-title{font-weight:600;font-size:15px;margin-bottom:6px}.changelog-body{font-size:13px;color:var(--ink-soft);display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.changelog-actions{display:flex;flex-direction:column;gap:6px;flex-shrink:0}@media (max-width: 720px){.changelog-row{flex-direction:column;gap:12px}.changelog-actions{flex-direction:row;width:100%}.changelog-actions .btn:not(.icon){flex:1}}.admin-side{background:var(--ink);color:#cfd6e6;display:flex;flex-direction:column;padding:18px 0}.admin-side .brand{padding:0 22px 16px;display:flex;align-items:center;gap:10px;border-bottom:1px solid rgba(255,255,255,.08)}.admin-side .brand .logo-mark{width:36px;height:36px;border-radius:9px;background:linear-gradient(135deg,var(--brand),var(--accent));display:grid;place-items:center;color:#06302c;font-weight:800}.admin-side .brand .name{font-weight:700;color:#fff;font-size:14px}.admin-side .brand .role{font-size:11px;color:#8d97b3}.admin-side nav{margin-top:14px;flex:1}.admin-side .nav-item{display:flex;align-items:center;gap:11px;padding:10px 22px;color:#b0bbd6;font-size:13px;cursor:pointer;border-left:3px solid transparent}.admin-side .nav-item:hover{background:#ffffff0d;color:#fff}.admin-side .nav-item.on{background:#14b8a614;color:#fff;border-left-color:var(--brand)}.admin-side .foot{padding:14px 22px;display:flex;flex-direction:column;gap:8px}.admin-side .foot .btn{width:100%;background:#ffffff0a;color:#b0bbd6;border-color:#ffffff14;justify-content:center}.admin-side .foot .btn:hover{background:#ffffff14;color:#fff}.admin-main{padding:32px;overflow-y:auto;height:100vh}.admin-head{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:24px;gap:16px;flex-wrap:wrap}.admin-head h1{margin:0;font-size:22px}.admin-head .sub{font-size:13px;color:var(--ink-mute);margin-top:4px}.hub-kpis{display:grid;grid-template-columns:repeat(3,1fr);gap:0;background:var(--surface);border:1px solid var(--line);border-radius:var(--radius-lg);padding:24px 0;margin-bottom:22px}.hub-kpi{padding:4px 28px;border-right:1px solid var(--line);text-align:center}.hub-kpi:last-child{border-right:0}.hub-kpi-lbl{font-size:11px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--ink-mute);margin-bottom:10px}.hub-kpi-val{font-size:38px;font-weight:700;line-height:1;color:var(--ink);letter-spacing:-.02em}.hub-kpi-trend{font-size:13px;font-weight:500;margin-top:8px;display:inline-flex;align-items:center;gap:4px}.hub-kpi-trend.up{color:var(--ok)}.hub-kpi-trend.down{color:var(--danger)}.hub-kpi-trend.flat{color:var(--ink-mute)}@media (max-width: 720px){.hub-kpis{grid-template-columns:1fr;padding:12px 0}.hub-kpi{padding:14px 20px;border-right:0;border-bottom:1px solid var(--line)}.hub-kpi:last-child{border-bottom:0}}.hub-card{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius-lg);margin-bottom:18px}.hub-card-head{padding:18px 22px;border-bottom:1px solid var(--line);display:flex;align-items:flex-start;justify-content:space-between}.hub-card-head h3{font-size:16px;font-weight:700;color:var(--ink)}.hub-card-body{padding:22px}.hub-two-col{display:grid;grid-template-columns:1fr 1fr;gap:18px;margin-bottom:18px}.hub-two-col .hub-card{margin-bottom:0}@media (max-width: 920px){.hub-two-col{grid-template-columns:1fr}}.chart-x-axis{display:flex;justify-content:space-between;font-size:11px;color:var(--ink-mute);margin-top:8px;padding:0 4px;font-family:var(--font-mono)}#chartSeries .axis{stroke:var(--line);stroke-width:1}#chartSeries .grid{stroke:var(--line);stroke-width:1;stroke-dasharray:2 4}#chartSeries .grid-label{fill:var(--ink-mute);font-size:11px;font-family:var(--font-mono)}#chartSeries .area{fill:url(#chartGrad);opacity:.3}#chartSeries .line{stroke:var(--brand);stroke-width:2;fill:none}#chartSeries .dot{fill:#fff;stroke:var(--brand);stroke-width:2;r:4}.funnel-table{font-size:13px}.funnel-head{display:grid;grid-template-columns:1fr 80px 110px;font-size:11px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--ink-mute);padding-bottom:10px;border-bottom:1px solid var(--line)}.funnel-row{display:grid;grid-template-columns:1fr 80px 110px;align-items:center;padding:14px 0;border-bottom:1px solid var(--line)}.funnel-row:last-child{border-bottom:0}.funnel-bar-wrap{display:flex;align-items:center;gap:10px;min-width:0}.funnel-label{font-size:12px;color:var(--ink-soft);width:90px;flex-shrink:0}.funnel-bar{flex:1;height:32px;background:var(--surface-2);border-radius:5px;overflow:hidden;position:relative}.funnel-bar-fill{height:100%;border-radius:5px;display:flex;align-items:center;justify-content:flex-end;padding-right:10px;color:#fff;font-weight:700;font-size:12px}.funnel-count{text-align:right;font-weight:700;font-size:14px}.funnel-rate{text-align:right;font-size:13px;color:var(--ink-soft);font-weight:600}.donut-wrap{display:flex;align-items:center;gap:28px;justify-content:center;padding:14px 0;flex-wrap:wrap}.donut-legend{display:flex;flex-direction:column;gap:10px;font-size:13px}.donut-legend .leg{display:flex;align-items:center;gap:8px}.donut-legend .leg .dot{width:10px;height:10px;border-radius:50%;display:inline-block}.donut-legend .leg b{margin-left:auto;padding-left:14px;font-weight:700}.hub-table{width:100%;border-collapse:collapse}.hub-table th{font-size:11px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--ink-mute);text-align:left;padding:10px 14px;background:var(--surface-2);border-bottom:1px solid var(--line)}.hub-table td{padding:12px 14px;font-size:13px;border-bottom:1px solid var(--line)}.hub-table tr:last-child td{border-bottom:0}.hub-table tr:hover td{background:var(--surface-2)}.kpi-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(190px,1fr));gap:14px;margin-bottom:20px}.kpi{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius-lg);padding:18px;position:relative;overflow:hidden}.kpi:before{content:"";position:absolute;top:-50%;right:-30%;width:100px;height:100px;background:radial-gradient(circle,var(--brand-glow),transparent 70%);pointer-events:none}.kpi .lbl{font-size:11px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--ink-mute)}.kpi .val{font-size:28px;font-weight:700;margin-top:4px;line-height:1.1}.kpi .meta{font-size:11px;color:var(--ink-mute);margin-top:6px}.kpi.brand:before{background:radial-gradient(circle,var(--brand-glow),transparent 70%)}.kpi.accent:before{background:radial-gradient(circle,var(--accent-glow),transparent 70%)}.range-tabs{display:inline-flex;background:var(--surface-2);border-radius:8px;padding:3px}.range-tabs button{border:none;background:transparent;padding:6px 12px;border-radius:6px;font-size:12px;font-weight:600;color:var(--ink-soft)}.range-tabs button.on{background:var(--surface);color:var(--ink);box-shadow:var(--shadow-sm)}.table{width:100%;border-collapse:separate;border-spacing:0;background:var(--surface);border:1px solid var(--line);border-radius:var(--radius-lg);overflow:hidden}.table th,.table td{padding:12px 16px;text-align:left;font-size:13px;border-bottom:1px solid var(--line)}.table th{font-size:11px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--ink-mute);background:var(--surface-2)}.table tr:last-child td{border-bottom:0}.table tr:hover td{background:var(--surface-2)}.admin-tabs{display:inline-flex;background:var(--surface-2);border-radius:8px;padding:3px;flex-wrap:wrap}.admin-tabs button{border:none;background:transparent;padding:8px 14px;border-radius:6px;font-size:12px;font-weight:600;color:var(--ink-soft);display:inline-flex;align-items:center;gap:6px}.admin-tabs button.on{background:var(--surface);color:var(--ink);box-shadow:var(--shadow-sm)}.admin-tabs button .badge{display:inline-flex;align-items:center;justify-content:center;min-width:20px;height:18px;padding:0 6px;background:var(--line-strong);color:var(--ink);border-radius:999px;font-size:10px;font-weight:700}.admin-tabs button.on .badge{background:var(--brand);color:#06302c}.sug-card{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius-lg);padding:18px 20px;margin-bottom:12px;transition:border-color .12s ease,transform .12s ease}.sug-card:hover{border-color:var(--line-strong)}.sug-card .head-row{display:flex;align-items:flex-start;justify-content:space-between;gap:14px;margin-bottom:10px}.sug-card .chips-row{display:flex;gap:6px;flex-wrap:wrap}.sug-card .body{font-size:14px;color:var(--ink);line-height:1.5}.sug-card .body.truncate{display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.sug-card .actions{display:flex;gap:8px;margin-top:14px;align-items:center}.sug-card .actions .spacer{flex:1}.sug-card .actions .meta{font-size:12px;color:var(--ink-mute);display:inline-flex;align-items:center;gap:4px}.sug-card .actions .meta+.meta{margin-left:14px}.sug-card .actions select.status-quick{font-size:12px;padding:5px 26px 5px 10px;border-radius:6px;border:1px solid var(--line-strong);background:var(--surface);color:var(--ink);font-weight:600}.sug-card.s-resuelta{background:linear-gradient(180deg,rgba(34,197,94,.02),transparent)}.sug-card.s-archivada{opacity:.65}.chip.t-mejora{background:#6366f11f;color:var(--accent)}.chip.t-error{background:#ef44441f;color:#b1232c}.chip.t-nueva_funcion{background:#14b8a61f;color:var(--brand-ink)}.chip.t-integracion{background:#f59e0b29;color:#8a5300}.chip.t-otro{background:var(--surface-2);color:var(--ink-soft)}.chip.st-nueva{background:#6366f11f;color:var(--accent)}.chip.st-en_proceso{background:#f59e0b29;color:#8a5300}.chip.st-resuelta{background:#22c55e1f;color:#176c34}.chip.st-archivada{background:var(--surface-2);color:var(--ink-mute)}.admin-section{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius-lg);padding:24px;margin-bottom:20px}.admin-section h3{margin:0 0 4px;font-size:14px;display:flex;align-items:center;gap:8px}.admin-section h3 .ico{width:28px;height:28px;border-radius:8px;background:linear-gradient(135deg,var(--brand-glow),var(--accent-glow));display:grid;place-items:center;color:var(--brand)}.admin-section .desc{font-size:12px;color:var(--ink-mute);margin:0 0 16px}.field-grid{display:grid;gap:14px}.field-grid.cols-2{grid-template-columns:1fr 1fr}@media (max-width: 720px){.field-grid.cols-2{grid-template-columns:1fr}}.admin-preset-card{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius-lg);padding:18px 20px;margin-bottom:14px}.admin-preset-row{display:flex;gap:16px;align-items:flex-start}.admin-preset-fields{flex:1;min-width:0}.admin-preset-actions{display:flex;flex-direction:column;gap:6px;flex-shrink:0}.option-grid.tight{grid-template-columns:repeat(auto-fill,minmax(110px,1fr));gap:6px}.option-grid.tight .opt{padding:8px 6px;font-size:11px}.login-page{min-height:100vh;display:grid;place-items:center;background:var(--dark-bg);padding:20px}.login-card{background:var(--surface);border-radius:var(--radius-lg);padding:36px 32px;width:100%;max-width:420px;box-shadow:var(--shadow-lg)}.login-card .logo-mark{width:56px;height:56px;background:linear-gradient(135deg,var(--brand),var(--accent));border-radius:14px;margin:0 auto 16px;display:grid;place-items:center;color:#06302c;font-weight:800;font-size:22px;box-shadow:0 12px 30px var(--brand-glow)}.login-card h1{margin:0;text-align:center;font-size:18px;letter-spacing:.04em}.login-card .role-chip{display:block;text-align:center;font-size:12px;color:var(--ink-mute);margin:6px 0 22px;letter-spacing:.04em;text-transform:uppercase}.login-card p.helper{color:var(--ink-soft);font-size:13px;text-align:center;margin:0 0 20px}.login-back{text-align:center;margin-top:18px;font-size:13px}.login-error{background:#ef44441a;border:1px solid rgba(239,68,68,.3);color:#a01818;padding:8px 12px;border-radius:8px;font-size:13px;margin-bottom:12px;display:none}.login-error.on{display:block}.dash-card-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-bottom:20px}@media (max-width: 720px){.dash-card-grid{grid-template-columns:1fr}}.dash-card{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius-lg);padding:16px}.dash-card .ttl{font-size:11px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--ink-mute);display:flex;align-items:center;gap:8px;margin-bottom:10px}.dash-card .ttl .ico{width:22px;height:22px;border-radius:6px;background:#22c55e21;color:#176c34;display:grid;place-items:center;font-size:12px}.dash-card .ttl.accent .ico{background:#6366f121;color:var(--accent)}.dash-card .content{font-size:13px;color:var(--ink-soft)}.dash-card .content.empty{color:var(--ink-mute)}
