@import url("https://fonts.googleapis.com/css2?family=IBM+Plex+Mono:wght@400;500;600&family=Noto+Sans+KR:wght@400;500;600;700&display=swap");*{box-sizing:border-box;margin:0;padding:0}:root{--bg:#fafafa;--card:#fff;--border:#e5e5e5;--text:#0a0a0a;--text-secondary:#525252;--text-muted:#a3a3a3;--accent:#dc2626;--accent-hover:#b91c1c;--sidebar-bg:#0a0a0a;--sidebar-text:#a3a3a3;--sidebar-active:#fff;--success:#16a34a;--warning:#d97706;--danger:#dc2626;--mono:"IBM Plex Mono","SF Mono",monospace;--sans:"Noto Sans KR",-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif}html{font-size:14px}body{font-family:var(--sans);background:var(--bg);line-height:1.6;-webkit-font-smoothing:antialiased}a,body{color:var(--text)}a{text-decoration:none}a:hover{color:var(--accent)}.app-layout{display:flex;min-height:100vh}.sidebar{width:220px;background:var(--sidebar-bg);color:var(--sidebar-text);position:fixed;top:0;left:0;bottom:0;display:flex;flex-direction:column;z-index:100}.sidebar-logo{padding:28px 24px 24px;border-bottom:1px solid #1a1a1a}.sidebar-logo .logo-main{font-size:15px;font-weight:700;color:#fff;letter-spacing:-.3px}.sidebar-logo .logo-sub{font-size:11px;color:var(--sidebar-text);margin-top:2px;font-family:var(--mono)}.sidebar-nav{list-style:none;padding:12px 0;flex:1 1}.sidebar-nav li a{display:flex;align-items:center;gap:10px;padding:10px 24px;color:var(--sidebar-text);font-size:13px;font-weight:500;transition:color .15s;border-left:2px solid transparent}.sidebar-nav li a:hover{color:var(--sidebar-active);text-decoration:none}.sidebar-nav li a.active{color:var(--sidebar-active);border-left-color:var(--accent);background:hsla(0,0%,100%,.04)}.sidebar-nav li a svg{width:16px;height:16px;opacity:.6;flex-shrink:0}.sidebar-nav li a.active svg,.sidebar-nav li a:hover svg{opacity:1}.sidebar-footer{padding:16px 24px;border-top:1px solid #1a1a1a;font-size:11px;color:#404040;font-family:var(--mono)}.main-content{margin-left:220px;flex:1 1;padding:32px 40px;max-width:1200px}.page-header{margin-bottom:32px}.page-header .breadcrumb{font-size:12px;color:var(--text-muted);margin-bottom:8px;font-family:var(--mono)}.page-header .breadcrumb a{color:var(--text-muted)}.page-header .breadcrumb a:hover{color:var(--accent)}.page-header h1{font-size:22px;font-weight:700;letter-spacing:-.5px;line-height:1.3}.page-header p{color:var(--text-secondary);font-size:13px;margin-top:4px}.card{background:var(--card);border:1px solid var(--border);padding:24px;margin-bottom:16px}.card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px}.card-title{font-size:13px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;color:var(--text-secondary)}.stat-grid{display:grid;grid-template-columns:repeat(4,1fr);grid-gap:1px;gap:1px;background:var(--border);border:1px solid var(--border);margin-bottom:16px}.stat-card{background:var(--card);padding:20px 24px}.stat-card .label{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;color:var(--text-muted);margin-bottom:8px}.stat-card .value{font-size:28px;font-weight:700;font-family:var(--mono);letter-spacing:-1px}.stat-card .value .unit{font-size:13px;font-weight:500;color:var(--text-secondary);margin-left:2px}.table-wrapper{overflow-x:auto;margin:0 -24px;padding:0 24px}table{width:100%;border-collapse:collapse;font-size:13px}thead th{text-align:left;padding:10px 16px;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;color:var(--text-muted);border-bottom:2px solid var(--text);white-space:nowrap}tbody td{padding:10px 16px;border-bottom:1px solid var(--border);vertical-align:middle}tbody tr:hover{background:#f5f5f5}tbody td a{font-weight:500}tbody td a:hover{color:var(--accent)}td.mono{font-size:12px;letter-spacing:-.3px}.badge,td.mono{font-family:var(--mono)}.badge{display:inline-block;padding:2px 8px;font-size:11px;font-weight:600;letter-spacing:.3px;text-transform:uppercase}.badge-new{background:#0a0a0a;color:#fff}.badge-changed{background:#fef3c7;color:#92400e}.badge-closed{background:#fee2e2;color:#991b1b}.badge-success{background:#dcfce7;color:#166534}.badge-failed{background:#fee2e2;color:#991b1b}.badge-running{background:#dbeafe;color:#1d4ed8}.badge-queued{background:#f5f5f5;color:#525252}.badge-open{background:#dcfce7;color:#166534}.filter-bar{display:flex;gap:12px;flex-wrap:wrap;align-items:flex-end}.filter-bar+.filter-bar{margin-top:12px}.form-group{display:flex;flex-direction:column;gap:4px}.form-group label{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;color:var(--text-muted)}input[type=date],input[type=text],select{padding:7px 10px;border:1px solid var(--border);background:var(--card);font-size:13px;font-family:var(--sans);outline:none;transition:border-color .15s}input:focus,select:focus{border-color:var(--text)}input::placeholder{color:var(--text-muted)}.btn{padding:7px 16px;font-size:12px;font-weight:600;font-family:var(--sans);text-transform:uppercase;letter-spacing:.5px;border:none;cursor:pointer;transition:all .15s;white-space:nowrap}.btn-primary{background:var(--text);color:#fff}.btn-primary:hover{background:#262626}.btn-accent{background:var(--accent);color:#fff}.btn-accent:hover{background:var(--accent-hover)}.btn-outline{background:transparent;border:1px solid var(--border);color:var(--text-secondary)}.btn-outline:hover{border-color:var(--text);color:var(--text)}.btn-sm{padding:5px 12px;font-size:11px}.pagination{display:flex;align-items:center;justify-content:center;gap:8px;margin-top:20px}.pagination button{padding:5px 14px;border:1px solid var(--border);background:var(--card);cursor:pointer;font-size:12px;font-family:var(--mono);transition:all .15s}.pagination button:hover:not(:disabled){border-color:var(--text)}.pagination button:disabled{opacity:.3;cursor:not-allowed}.pagination span{font-size:12px;color:var(--text-muted);font-family:var(--mono)}.timeline{position:relative;padding-left:24px}.timeline:before{content:"";position:absolute;left:4px;top:0;bottom:0;width:1px;background:var(--border)}.timeline-item{position:relative;padding-bottom:24px}.timeline-item:before{content:"";position:absolute;left:-22px;top:6px;width:9px;height:9px;background:var(--accent)}.timeline-item .date{font-size:12px;font-family:var(--mono);color:var(--text-secondary);margin-bottom:6px;display:flex;align-items:center;gap:8px}.timeline-item .diff{font-size:13px;background:#f5f5f5;border:1px solid var(--border);padding:12px 16px;margin-top:8px}.diff-row{display:flex;gap:8px;padding:3px 0;font-size:12px;align-items:baseline}.diff-field{font-weight:600;min-width:72px;color:var(--text-secondary)}.diff-old{color:var(--danger);text-decoration:line-through}.diff-new{color:var(--success);font-weight:500}.diff-arrow{color:var(--text-muted);font-family:var(--mono)}.detail-grid{display:grid;grid-template-columns:120px 1fr;grid-gap:0;gap:0;font-size:13px}.detail-grid dt{color:var(--text-muted);font-weight:500}.detail-grid dd,.detail-grid dt{padding:8px 0;border-bottom:1px solid var(--border)}.detail-grid dd:last-of-type,.detail-grid dt:last-of-type{border-bottom:none}.loading{font-family:var(--mono);font-size:12px;text-transform:uppercase;letter-spacing:1px}.empty,.loading{text-align:center;padding:60px;color:var(--text-muted)}.empty{font-size:13px}.count-label{font-size:12px;color:var(--text-muted);font-family:var(--mono);margin-bottom:12px}.count-label strong{color:var(--text)}.section-divider{border:none;border-top:1px solid var(--border);margin:24px 0}.sidebar-user{padding:16px 24px;border-top:1px solid #1a1a1a}.sidebar-user-email{font-size:12px;color:#d4d4d4;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.sidebar-user-meta{display:flex;align-items:center;justify-content:space-between;margin-top:6px}.sidebar-user-role{font-size:10px;font-family:var(--mono);text-transform:uppercase;letter-spacing:.5px;color:#525252;background:#1a1a1a;padding:2px 6px}.sidebar-logout-btn{background:none;border:none;color:#525252;font-size:11px;cursor:pointer;font-family:var(--sans);padding:0}.sidebar-logout-btn:hover{color:var(--accent)}.auth-layout{background:var(--bg)}.auth-container,.auth-layout{min-height:100vh;display:flex;align-items:center;justify-content:center}.auth-container{width:100%}.auth-card{width:100%;max-width:380px;padding:40px;background:var(--card);border:1px solid var(--border)}.auth-header{text-align:center;margin-bottom:32px}.auth-logo{font-size:18px;font-weight:700;letter-spacing:-.5px;margin-bottom:12px}.auth-header h1{font-size:16px;font-weight:600;color:var(--text-secondary)}.auth-card form .form-group{margin-bottom:16px}.auth-btn,.auth-card form .form-group input{width:100%}.auth-btn{padding:10px 16px;margin-top:8px}.auth-btn:disabled{opacity:.5;cursor:not-allowed}.auth-error{background:#fef2f2;border:1px solid #fecaca;color:#991b1b;padding:10px 14px;font-size:13px;margin-bottom:16px}.auth-links{margin-top:20px;text-align:center;display:flex;justify-content:center;gap:16px}.auth-links a{font-size:12px;color:var(--text-muted)}.auth-links a:hover{color:var(--accent)}.region-bars{display:flex;flex-direction:column;gap:8px}.region-bar-row{display:flex;align-items:center;gap:12px}.region-label{font-size:12px;min-width:100px;color:var(--text-secondary);text-align:right}.region-bar-track{flex:1 1;height:20px;background:#f5f5f5;border:1px solid var(--border)}.region-bar-fill{height:100%;background:var(--text);transition:width .3s ease;min-width:2px}.region-count{font-size:12px;font-family:var(--mono);min-width:40px;color:var(--text-secondary)}.change-feed{display:flex;flex-direction:column}.change-feed-item{padding:14px 0;border-bottom:1px solid var(--border)}.change-feed-item:last-child{border-bottom:none}.change-feed-header{display:flex;align-items:center;gap:10px;flex-wrap:wrap}.change-feed-name{font-weight:600;font-size:14px}.change-feed-meta{font-size:12px;color:var(--text-muted)}.change-feed-diff{margin-top:8px;display:flex;flex-wrap:wrap;gap:6px 16px;padding:8px 12px;background:#f9f9f9;border:1px solid var(--border);font-size:12px}.diff-inline{display:inline-flex;align-items:baseline;gap:4px}.plan-notice{display:inline-block;font-size:11px;color:var(--text-muted);background:#f5f5f5;border:1px solid var(--border);padding:3px 10px;margin-left:8px;font-weight:400}.plan-compare{display:grid;grid-template-columns:1fr 1fr;grid-gap:16px;gap:16px}.plan-col{border:1px solid var(--border);padding:24px;display:flex;flex-direction:column}.plan-col-pro{border-color:var(--accent);background:#fafafa}.plan-name{font-size:18px;font-weight:700;margin-bottom:4px}.plan-price{margin-bottom:20px;font-family:var(--mono);display:flex;flex-direction:column;gap:4px}.plan-col:not(.plan-col-pro) .plan-price{font-size:14px;color:var(--text-muted)}.plan-price-original{font-size:13px;color:var(--text-muted);text-decoration:line-through}.plan-price-discount{font-size:22px;font-weight:700;color:var(--accent)}.plan-price-save{display:inline-block;width:-moz-fit-content;width:fit-content;font-size:12px;font-weight:700;color:#fff;background:var(--danger);padding:2px 8px;font-family:var(--sans)}.plan-features{list-style:none;padding:0;margin:0 0 20px;display:flex;flex-direction:column;gap:10px;flex:1 1}.plan-features li{font-size:13px;color:var(--text-secondary);padding-left:20px;position:relative}.plan-features li:before{content:"·";position:absolute;left:6px;color:var(--text-muted)}.plan-feature-highlight{color:var(--text)!important;font-weight:500}.plan-feature-highlight:before{content:"\2713"!important;color:var(--accent)!important;font-weight:700}.plan-current{font-size:12px;text-align:center;color:var(--text-muted);padding:8px;border:1px solid var(--border)}@media (max-width:1024px){.stat-grid{grid-template-columns:repeat(2,1fr)}}@media (max-width:768px){.sidebar{display:none}.main-content{margin-left:0;padding:20px}.plan-compare,.stat-grid{grid-template-columns:1fr}}