@import url("https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800&display=swap");:root{--navy:#f8fafc;--navy-light:#ffffff;--navy-card:#ffffff;--navy-border:#e2e8f0;--navy-hover:#f1f5f9;--gold:#4f46e5;--gold-light:#6366f1;--gold-dark:#4338ca;--gold-glow:rgba(79,70,229,0.1);--purple:#4f46e5;--purple-light:#6366f1;--purple-dark:#4338ca;--purple-glow:rgba(79,70,229,0.08);--green:#10b981;--green-glow:rgba(16,185,129,0.1);--red:#ef4444;--red-glow:rgba(239,68,68,0.1);--amber:#f59e0b;--text-primary:#1e293b;--text-muted:#475569;--text-dim:#64748b;--sidebar-width:248px;--topbar-height:56px;--radius:8px;--radius-lg:12px;--radius-xl:16px;--transition:0.15s ease;--font:"Inter",-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif}*,:after,:before{margin:0;padding:0;box-sizing:border-box}html{font-size:14px;-webkit-font-smoothing:antialiased}body{font-family:var(--font);background:var(--navy);color:var(--text-primary);line-height:1.5;overflow:hidden}a{color:var(--gold);text-decoration:none}button{cursor:pointer}button,input,select,textarea{font-family:var(--font)}.app{display:flex;height:100vh}.main-area{flex:1 1;display:flex;flex-direction:column;overflow:hidden}.page-content{flex:1 1;overflow-y:auto;padding:28px 32px}.sidebar{width:var(--sidebar-width);background:#1e1b4b;border-right:1px solid var(--navy-border);display:flex;flex-direction:column;flex-shrink:0}.sidebar-logo{padding:20px 20px 24px;gap:12px;border-bottom:1px solid rgba(255,255,255,.1)}.logo-mark,.sidebar-logo{display:flex;align-items:center}.logo-mark{width:36px;height:36px;background:rgba(255,255,255,.1);border:2px solid rgba(255,255,255,.3);border-radius:10px;justify-content:center;font-weight:800;font-size:.95rem;color:#fff;flex-shrink:0}.logo-text{font-size:1rem;font-weight:700;color:#fff;line-height:1.2}.logo-text span{display:block;font-size:.75rem;font-weight:400;color:rgba(255,255,255,.5);margin-top:2px}.sidebar-nav{flex:1 1;padding:16px 12px;overflow-y:auto}.nav-section{margin-bottom:24px}.nav-section-title{font-size:.7rem;font-weight:600;text-transform:uppercase;letter-spacing:.08em;color:rgba(255,255,255,.4);padding:0 12px;margin-bottom:8px}.nav-item{display:flex;align-items:center;gap:10px;padding:9px 12px;border-radius:6px;color:rgba(255,255,255,.65);font-size:.9rem;font-weight:500;transition:all var(--transition);cursor:pointer;text-decoration:none;margin-bottom:2px}.nav-item:hover{background:rgba(255,255,255,.08);color:#fff}.nav-item.active{background:var(--gold);color:#fff}.nav-item i{width:18px;text-align:center;font-size:.85rem}.nav-badge{margin-left:auto;background:rgba(255,255,255,.1);color:rgba(255,255,255,.8);font-size:.7rem;font-weight:600;padding:2px 8px;border-radius:10px}.sidebar-footer{padding:16px 20px;border-top:1px solid rgba(255,255,255,.1)}.sidebar-footer-text{font-size:.75rem;color:rgba(255,255,255,.4)}.topbar{height:var(--topbar-height);background:#fff;border-bottom:1px solid var(--navy-border);display:flex;align-items:center;padding:0 32px;gap:16px;flex-shrink:0}.topbar-title{font-size:1.1rem;font-weight:700;color:var(--text-primary)}.topbar-subtitle{font-size:.85rem;color:var(--text-dim);margin-left:4px}.topbar-spacer{flex:1 1}.topbar-badge{background:var(--navy);border:1px solid var(--navy-border);padding:5px 14px;border-radius:20px;font-size:.8rem;color:var(--text-muted);font-weight:500}.card{background:var(--navy-card);border:1px solid var(--navy-border);border-radius:var(--radius-lg);padding:24px;transition:all .2s ease}.card:hover{border-color:var(--gold);box-shadow:0 4px 20px rgba(79,70,229,.08)}.card-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}.card-title{font-size:1rem;font-weight:600}.card-title,.card-value{color:var(--text-primary)}.card-value{font-size:2rem;font-weight:800;line-height:1}.card-label{font-size:.8rem;color:var(--text-dim);margin-top:4px;text-transform:uppercase;letter-spacing:.05em;font-weight:600}.card-icon{width:40px;height:40px;border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:1.1rem}.card-icon.purple{background:var(--purple-glow);color:var(--purple-light)}.card-icon.gold{background:var(--gold-glow);color:var(--gold)}.card-icon.green{background:var(--green-glow);color:var(--green)}.card-icon.red{background:var(--red-glow);color:var(--red)}.stats-grid{display:grid;grid-template-columns:repeat(4,1fr);grid-gap:20px;gap:20px;margin-bottom:28px}.table-container{background:var(--navy-card);border:1px solid var(--navy-border);border-radius:var(--radius-lg);overflow:hidden}.table-header{padding:16px 24px;border-bottom:1px solid var(--navy-border);display:flex;align-items:center;justify-content:space-between}.table-title{font-size:1rem;font-weight:600}table{width:100%;border-collapse:collapse}thead th{padding:12px 16px;text-align:left;font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:var(--text-dim);border-bottom:1px solid var(--navy-border);background:var(--navy)}tbody td{padding:14px 16px;font-size:.9rem;color:var(--text-muted);border-bottom:1px solid rgba(51,65,85,.4)}tbody tr{transition:background .12s;cursor:pointer}tbody tr:hover{background:var(--navy-hover)}tbody tr:last-child td{border-bottom:none}.status-dot{width:8px;height:8px;border-radius:50%;display:inline-block;margin-right:8px}.status-dot.green{background:var(--green);box-shadow:0 0 8px var(--green-glow)}.status-dot.amber{background:var(--amber);box-shadow:0 0 8px var(--gold-glow)}.status-dot.red{background:var(--red);box-shadow:0 0 8px var(--red-glow)}.status-dot.purple{background:var(--purple);box-shadow:0 0 8px var(--purple-glow)}.badge{display:inline-flex;align-items:center;gap:6px;padding:4px 12px;border-radius:20px;font-size:.75rem;font-weight:600}.badge.green{background:var(--green-glow);color:var(--green)}.badge.amber{background:var(--gold-glow);color:var(--gold)}.badge.red{background:var(--red-glow);color:var(--red)}.badge.purple{background:var(--purple-glow);color:var(--purple-light)}.badge.neutral{background:rgba(100,116,139,.15);color:var(--text-dim)}.btn{display:inline-flex;align-items:center;gap:8px;padding:9px 20px;border-radius:6px;font-size:.85rem;font-weight:600;border:none;cursor:pointer;transition:all var(--transition)}.btn-primary{background:var(--gold);color:#fff}.btn-primary:hover{background:var(--gold-dark);box-shadow:0 4px 16px var(--gold-glow)}.btn-gold{background:var(--gold);color:#fff}.btn-gold:hover{background:var(--gold-dark);box-shadow:0 4px 16px var(--gold-glow)}.btn-outline{background:transparent;color:var(--text-muted);border:1px solid var(--navy-border)}.btn-outline:hover{border-color:var(--gold);color:var(--gold-light)}.btn-danger{background:var(--red);color:#fff}.btn-danger:hover{background:#dc2626}.btn-success{background:var(--green);color:#fff}.btn-success:hover{background:#059669}.btn-sm{padding:6px 14px;font-size:.8rem}.btn-lg{padding:12px 28px;font-size:.95rem}.btn:disabled{opacity:.5;cursor:not-allowed}.form-group{margin-bottom:20px}.form-label{display:block;font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:var(--text-dim);margin-bottom:8px}.form-control{width:100%;padding:10px 14px;background:#fff;border:1px solid var(--navy-border);border-radius:6px;color:var(--text-primary);font-size:.9rem;transition:border-color var(--transition)}.form-control:focus{outline:none;border-color:var(--gold);box-shadow:0 0 0 3px var(--gold-glow)}.form-control::placeholder{color:var(--text-dim)}select.form-control{-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%2394a3b8' stroke-width='2'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center;padding-right:36px}textarea.form-control{resize:vertical;min-height:100px}.stepper{gap:0;margin-bottom:32px;padding:0 16px}.stepper,.stepper-step{display:flex;align-items:center}.stepper-step{gap:10px;flex:1 1;position:relative}.stepper-step:not(:last-child):after{content:"";flex:1 1;height:2px;background:var(--navy-border);margin:0 12px}.stepper-step.completed:not(:last-child):after{background:var(--green)}.stepper-step.active:not(:last-child):after{background:linear-gradient(90deg,var(--gold),var(--navy-border))}.stepper-number{width:32px;height:32px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.8rem;font-weight:700;flex-shrink:0;border:2px solid var(--navy-border);color:var(--text-dim);background:#fff}.stepper-step.active .stepper-number{border-color:var(--gold);color:#fff;background:var(--gold);box-shadow:0 0 16px var(--gold-glow)}.stepper-step.completed .stepper-number{border-color:var(--green);color:#fff;background:var(--green)}.stepper-step.rejected .stepper-number{border-color:var(--red);color:#fff;background:var(--red)}.stepper-label{font-size:.8rem;font-weight:500;color:var(--text-dim);white-space:nowrap}.stepper-step.active .stepper-label{color:var(--text-primary);font-weight:600}.stepper-step.completed .stepper-label{color:var(--green)}.progress-bar{height:6px;background:var(--navy-border);border-radius:3px;overflow:hidden}.progress-fill{height:100%;background:linear-gradient(90deg,var(--gold-dark),var(--gold-light));border-radius:3px;transition:width .5s ease}.tag{display:inline-flex;align-items:center;gap:4px;padding:4px 10px;border-radius:6px;font-size:.75rem;font-weight:500;background:var(--navy);border:1px solid var(--navy-border);color:var(--text-muted);margin:2px}.tag .tag-remove{cursor:pointer;opacity:.6;margin-left:4px}.tag .tag-remove:hover{opacity:1;color:var(--red)}.tabs{display:flex;gap:0;border-bottom:1px solid var(--navy-border);margin-bottom:24px;overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:thin}.tabs::-webkit-scrollbar{height:4px}.tab{white-space:nowrap;flex-shrink:0;padding:12px 20px;font-size:.9rem;font-weight:500;color:var(--text-dim);cursor:pointer;border-bottom:2px solid transparent;transition:all var(--transition)}.tab:hover{color:var(--text-primary)}.tab.active{color:var(--gold);border-bottom-color:var(--gold);font-weight:600}.modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,.6);display:flex;align-items:center;justify-content:center;z-index:1000;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.modal{background:var(--navy-light);border:1px solid var(--navy-border);border-radius:var(--radius-xl);padding:32px;max-width:560px;width:90%;max-height:80vh;overflow-y:auto}.modal-title{font-size:1.2rem;font-weight:700;margin-bottom:16px}.modal-actions{display:flex;gap:12px;justify-content:flex-end;margin-top:24px}.toast-container{position:fixed;top:20px;right:20px;z-index:2000;display:flex;flex-direction:column;gap:8px}.toast{padding:12px 20px;border-radius:var(--radius);font-size:.85rem;font-weight:500;animation:slideIn .3s ease;min-width:280px;display:flex;align-items:center;gap:10px}.toast.success{background:var(--green);color:#fff}.toast.error{background:var(--red);color:#fff}.toast.info{background:var(--gold);color:#fff}.toast.warning{background:var(--amber);color:#fff}@keyframes slideIn{0%{transform:translateX(100%);opacity:0}to{transform:translateX(0);opacity:1}}.empty-state{text-align:center;padding:60px 20px;color:var(--text-dim)}.empty-state i{font-size:3rem;margin-bottom:16px;display:block;color:var(--navy-border)}.empty-state h3{font-size:1.1rem;color:var(--text-muted);margin-bottom:8px}.empty-state p{font-size:.9rem;margin-bottom:20px}.spinner{width:20px;height:20px;border:2px solid var(--navy-border);border-top-color:var(--gold);border-radius:50%;animation:spin .7s linear infinite;display:inline-block;vertical-align:middle}.spinner-lg{width:40px;height:40px;border-width:3px}@keyframes spin{to{transform:rotate(1turn)}}.loading-overlay{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px;gap:16px;color:var(--text-muted)}.grid-2{grid-template-columns:repeat(2,1fr);grid-gap:20px}.grid-2,.grid-3{display:grid;gap:20px}.grid-3{grid-template-columns:repeat(3,1fr);grid-gap:20px}.grid-4{display:grid;grid-template-columns:repeat(4,1fr);grid-gap:20px;gap:20px}.code-block{background:#f1f5f9;font-size:.8rem;color:var(--text-muted);overflow-x:auto}.code-block,.editor-area{border:1px solid var(--navy-border);border-radius:var(--radius);padding:16px;font-family:JetBrains Mono,Fira Code,monospace;line-height:1.6}.editor-area{width:100%;min-height:400px;background:#fff;color:var(--text-primary);font-size:.85rem;resize:vertical}.editor-area:focus{outline:none;border-color:var(--gold);box-shadow:0 0 0 3px var(--gold-glow)}.traffic-light{display:inline-flex;align-items:center;gap:6px}.traffic-light .dot{width:12px;height:12px;border-radius:50%}.traffic-light .dot.active-green{background:var(--green);box-shadow:0 0 10px var(--green)}.traffic-light .dot.active-amber{background:var(--amber);box-shadow:0 0 10px var(--amber)}.traffic-light .dot.active-red{background:var(--red);box-shadow:0 0 10px var(--red)}.traffic-light .dot.inactive{background:var(--navy-border)}.action-bar{display:flex;gap:12px;align-items:center;flex-wrap:wrap;margin-bottom:24px}.action-bar .spacer{flex:1 1}.data-warning{display:flex;align-items:center;gap:12px;padding:12px 20px;background:rgba(245,158,11,.1);border:1px solid rgba(245,158,11,.3);border-radius:var(--radius);margin-bottom:20px;font-size:.85rem;color:var(--gold-light)}.data-warning i{font-size:1.1rem;flex-shrink:0}.section{margin-bottom:28px}.section-title{font-size:1rem;font-weight:600;color:var(--text-primary);margin-bottom:16px;display:flex;align-items:center;gap:8px}.section-title i{color:var(--gold)}.town-list{flex-wrap:wrap}.town-add,.town-list{display:flex;gap:8px;margin-top:12px}.town-add input{flex:1 1}.kw-volume{color:var(--text-primary)}.kw-diff,.kw-volume{font-weight:600}.kw-diff.easy{color:var(--green)}.kw-diff.medium{color:var(--gold)}.kw-diff.hard{color:var(--red)}.stage-content{background:var(--navy-card);border:1px solid var(--navy-border);border-radius:var(--radius-lg);padding:28px;margin-bottom:20px}.stage-actions{display:flex;gap:12px;margin-top:20px}@media (max-width:1400px){.grid-4,.stats-grid{grid-template-columns:repeat(2,1fr)}}@media (max-width:1200px){.grid-3{grid-template-columns:repeat(2,1fr)}}.topbar-burger{display:none;background:transparent;border:0;cursor:pointer;padding:8px;margin-right:4px;flex-direction:column;gap:4px}.topbar-burger span{display:block;width:22px;height:2px;background:var(--text-primary,#1e293b);border-radius:2px}.sidebar-backdrop{display:none}@media (max-width:900px){.sidebar{position:fixed;top:0;left:0;bottom:0;z-index:200;transform:translateX(-100%);transition:transform .25s ease;box-shadow:4px 0 24px rgba(0,0,0,.3)}.sidebar.sidebar--mobile-open{transform:translateX(0)}.sidebar-backdrop{display:block;position:fixed;inset:0;z-index:150;background:rgba(0,0,0,.55);animation:fadeIn .2s ease}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.topbar-burger{display:flex}.page-content{padding:20px 16px}.stats-grid{grid-template-columns:1fr 1fr}.grid-2,.grid-3,.grid-4{grid-template-columns:1fr}.stepper{flex-wrap:wrap;gap:8px}.stepper-step:not(:last-child):after,.topbar-subtitle{display:none}table{display:block;overflow-x:auto;-webkit-overflow-scrolling:touch}.card,table{max-width:100%}}@media (max-width:600px){.stats-grid{grid-template-columns:1fr}.topbar{padding:0 12px;gap:8px}.topbar-badge{display:none}.topbar-title{font-size:1rem}.action-bar{flex-wrap:wrap}.page-content{padding:16px 12px}}