.app-layout{min-height:100vh;display:flex;flex-direction:column}.app-header{padding:1rem 2rem;display:flex;align-items:center;justify-content:space-between;position:sticky;top:0;z-index:100;border-bottom:1px solid rgba(255,255,255,.05)}.logo{display:flex;align-items:center;gap:.5rem}.logo h1{font-size:1.25rem;margin:0;font-weight:700;color:var(--text-primary);display:flex;align-items:center;gap:.5rem}.badge{font-size:.75rem;background:var(--primary-glow);color:var(--primary);padding:.1em .5em;border-radius:4px;text-transform:uppercase}.main-nav{display:flex;gap:.5rem}.nav-item{background:transparent;border:1px solid transparent;color:var(--text-secondary);padding:.5rem 1rem;border-radius:8px;cursor:pointer;display:flex;align-items:center;gap:.5rem;font-size:.9rem;transition:all .2s}.nav-item:hover{background:#ffffff0d;color:var(--text-primary)}.nav-item.active{background:var(--bg-card-hover);color:var(--primary);border-color:#8b5cf633}.main-content{flex:1;padding:2rem;max-width:1200px;margin:0 auto;width:100%;box-sizing:border-box}.scraper-view{display:flex;flex-direction:column;gap:1.5rem}.control-panel h2{margin-top:0;margin-bottom:1.5rem;font-size:1.5rem}.form-group{margin-bottom:1.5rem}.form-group label{display:block;margin-bottom:.5rem;color:var(--text-secondary);font-size:.9rem}.range-input{width:100%;accent-color:var(--primary)}.status-grid{display:grid;grid-template-columns:2fr 1fr;gap:1.5rem}@media (max-width: 768px){.status-grid{grid-template-columns:1fr}}.log-panel{height:300px;display:flex;flex-direction:column}.log-container{flex:1;background:#0000004d;border-radius:8px;padding:1rem;overflow-y:auto;font-family:Menlo,Monaco,monospace;font-size:.85rem;color:var(--text-secondary)}.log-line{margin-bottom:.4rem;border-bottom:1px solid rgba(255,255,255,.05);padding-bottom:.2rem}.status-panel{display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center}.pulse-indicator{width:100px;height:100px;border-radius:50%;background:var(--primary-glow);display:flex;align-items:center;justify-content:center;color:#fff;animation:pulse 2s infinite;margin-bottom:1rem}@keyframes pulse{0%{transform:scale(.95);box-shadow:0 0 #8b5cf6b3}70%{transform:scale(1);box-shadow:0 0 0 20px #8b5cf600}to{transform:scale(.95);box-shadow:0 0 #8b5cf600}}.idle-indicator{width:100px;height:100px;border-radius:50%;background:var(--bg-card-hover);display:flex;align-items:center;justify-content:center;color:var(--text-muted);margin-bottom:1rem;border:2px solid var(--border-color)}.status-message{font-size:1.1rem;font-weight:500}.data-table{width:100%;border-collapse:collapse;color:var(--text-primary)}.data-table th{text-align:left;padding:1rem;color:var(--text-secondary);font-weight:600;border-bottom:1px solid var(--border-color)}.data-table td{padding:1rem;border-bottom:1px solid rgba(255,255,255,.05)}.data-table tr:hover td{background:#ffffff05}.actions-cell{display:flex;gap:.5rem}.btn-icon{background:transparent;border:none;color:var(--text-secondary);cursor:pointer;padding:.5rem;border-radius:6px;transition:all .2s;display:flex;align-items:center;justify-content:center}.btn-icon:hover{background:#ffffff1a;color:var(--text-primary)}.btn-icon.danger:hover{background:#ef444433;color:var(--danger)}.empty-state{text-align:center;padding:3rem;color:var(--text-muted)}.notification-container{position:fixed;top:1rem;right:1rem;z-index:1000;display:flex;flex-direction:column;gap:.5rem;max-width:340px;pointer-events:none}.notification{background:var(--bg-card);border:1px solid var(--border-color);border-radius:12px;padding:.75rem 1rem;box-shadow:0 8px 24px #00000080;animation:slideInRight .3s ease;pointer-events:all}.notification-alert{border-color:#ef444480;background:#1e293bf2}.notification-info{border-color:#8b5cf666;background:#1e293bf2}@keyframes slideInRight{0%{transform:translate(110%);opacity:0}to{transform:translate(0);opacity:1}}.notification-header{display:flex;align-items:center;gap:.4rem;margin-bottom:.3rem;color:var(--text-secondary)}.notification-title{flex:1;font-weight:600;font-size:.88rem;color:var(--text-primary)}.notification-close{background:transparent;border:none;color:var(--text-muted);cursor:pointer;padding:.15rem;border-radius:4px;display:flex;align-items:center;line-height:1}.notification-close:hover{color:var(--text-primary)}.notification-body{font-size:.82rem;color:var(--text-secondary);margin:0 0 .4rem}.notification-preview{display:flex;flex-direction:column;gap:.2rem;padding-top:.4rem;border-top:1px solid rgba(255,255,255,.06)}.notif-review-item{display:flex;gap:.5rem;font-size:.78rem}.notif-stars{color:var(--warning);letter-spacing:-1px}.notif-author{color:var(--text-muted)}.nav-badge{background:var(--primary);color:#fff;font-size:.7rem;padding:.1em .45em;border-radius:999px;min-width:18px;text-align:center;line-height:1.4}.url-textarea{resize:vertical;font-family:Menlo,Monaco,monospace;font-size:.85rem;min-height:110px;line-height:1.6}.url-count{font-size:.78rem;color:var(--text-muted);text-align:right;margin-top:.3rem}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}@media (max-width: 640px){.form-row{grid-template-columns:1fr}}.form-group-half{margin-bottom:1rem}.star-selector{display:flex;gap:.6rem;flex-wrap:wrap;margin-top:.25rem}.star-option{display:flex;align-items:center;gap:.25rem;cursor:pointer;font-size:.9rem;color:var(--text-secondary)}.queue-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.queue-header h3{display:flex;align-items:center;gap:.5rem;margin:0;font-size:1.1rem}.processing-badge{font-size:.72rem;background:#8b5cf626;color:var(--primary);padding:.2em .6em;border-radius:999px;animation:pulse 2s infinite}.btn-sm{font-size:.82rem;padding:.4rem .8rem}.job-list{display:flex;flex-direction:column;gap:.5rem}.job-item{display:flex;align-items:center;gap:.75rem;padding:.7rem .9rem;background:#0003;border-radius:8px}.job-status-dot{width:9px;height:9px;border-radius:50%;flex-shrink:0}.job-info{flex:1;display:flex;flex-direction:column;gap:.15rem;overflow:hidden}.job-shop{font-weight:600;font-size:.88rem;color:var(--text-primary)}.job-url{font-size:.73rem;color:var(--text-muted);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.job-status-label{font-size:.8rem;font-weight:500;flex-shrink:0;white-space:nowrap}.monitor-view{display:flex;flex-direction:column;gap:1.5rem}.section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.section-header h2{margin:0}.monitor-list{display:flex;flex-direction:column;gap:.75rem}.monitor-item{background:#0003;border-radius:10px;padding:1rem 1.1rem;border:1px solid var(--border-color)}.monitor-item-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.6rem}.monitor-name{display:flex;align-items:center;gap:.5rem;font-size:.95rem}.monitor-actions{display:flex;gap:.25rem}.monitor-item-body{display:flex;flex-wrap:wrap;gap:.75rem 1.5rem;align-items:center;font-size:.83rem;margin-bottom:.5rem}.monitor-meta{display:flex;align-items:center;gap:.25rem;color:var(--text-secondary)}.monitor-url{font-size:.72rem;color:var(--text-muted);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;width:100%}.monitor-interval-control{display:flex;align-items:center;gap:.4rem;color:var(--text-secondary)}.status-dot{width:8px;height:8px;border-radius:50%;background:var(--success);flex-shrink:0}.status-dot.checking{background:var(--primary);animation:pulse 1s infinite}.checking-label{font-size:.75rem;color:var(--primary);font-weight:500}.error-label{font-size:.78rem;color:var(--danger);margin-top:.25rem}.select-sm{background:var(--bg-card-hover);border:1px solid var(--border-color);color:var(--text-primary);border-radius:6px;padding:.2rem .5rem;font-size:.8rem;cursor:pointer}.select-sm:focus{outline:none;border-color:var(--primary)}.login-container{min-height:100vh;display:flex;align-items:center;justify-content:center;background:var(--bg-base, #0f172a);padding:1rem}.login-card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:16px;padding:2.5rem 2rem;width:100%;max-width:400px;box-shadow:0 24px 64px #0009}.login-logo{text-align:center;margin-bottom:2rem}.login-logo h1{font-size:1.4rem;margin:.75rem 0 0;color:var(--text-primary)}.login-subtitle{font-size:.85rem;color:var(--text-muted);margin:.4rem 0 0}.login-error{background:#ef44441f;border:1px solid rgba(239,68,68,.3);color:var(--danger);border-radius:8px;padding:.6rem .9rem;font-size:.85rem;margin-bottom:1rem}.login-success{background:#22c55e1f;border:1px solid rgba(34,197,94,.3);color:var(--success);border-radius:8px;padding:.6rem .9rem;font-size:.85rem;margin-bottom:1rem}.btn-full{width:100%;justify-content:center}.user-info{display:flex;align-items:center;gap:.5rem;color:var(--text-secondary);font-size:.85rem;margin-left:auto;padding-left:1.5rem}.user-name{color:var(--text-primary);font-weight:500}.btn-link{background:transparent;border:none;color:var(--text-secondary);cursor:pointer;padding:.35rem;border-radius:6px;display:flex;align-items:center;transition:all .2s}.btn-link:hover{background:#ffffff1a;color:var(--text-primary)}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0009;display:flex;align-items:center;justify-content:center;z-index:2000;padding:1rem}.modal{background:var(--bg-card);border:1px solid var(--border-color);border-radius:16px;padding:1.75rem;width:100%;max-width:420px;box-shadow:0 24px 64px #000000b3}.modal-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem}.modal-header h3{margin:0;font-size:1.1rem;color:var(--text-primary)}.modal-footer{display:flex;justify-content:flex-end;gap:.75rem;margin-top:1.25rem}.modal-wide{max-width:760px;max-height:85vh;display:flex;flex-direction:column}.modal-wide .modal-header{flex-shrink:0}.review-list{overflow-y:auto;display:flex;flex-direction:column;gap:.75rem;padding-right:.25rem}.review-item{background:#ffffff0a;border:1px solid var(--border-color);border-radius:10px;padding:.9rem 1rem}.review-item-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.5rem}.review-meta{display:flex;align-items:center;gap:.6rem;flex-wrap:wrap}.review-author{font-weight:600;font-size:.9rem;color:var(--text-primary)}.review-stars{font-size:.85rem;color:#f59e0b;letter-spacing:1px}.review-date{font-size:.78rem;color:var(--text-muted)}.review-content{margin:0;font-size:.88rem;line-height:1.6;color:var(--text-secondary);white-space:pre-wrap;word-break:break-word}.review-no-text{font-style:italic;color:var(--text-muted)}.review-has-photo{display:inline-flex;align-items:center;color:#60a5fa;opacity:.85}.review-link-btn{display:inline-flex;align-items:center;gap:.35rem;margin-top:.5rem;font-size:.8rem;color:var(--primary);text-decoration:none;padding:.2rem .55rem;border:1px solid rgba(99,102,241,.35);border-radius:6px;transition:background .15s,border-color .15s}.review-link-btn:hover{background:#6366f11f;border-color:var(--primary)}.users-view{display:flex;flex-direction:column;gap:1.5rem}.role-badge{display:inline-flex;align-items:center;gap:.25rem;font-size:.75rem;padding:.15em .55em;border-radius:999px;background:#94a3b826;color:var(--text-secondary);border:1px solid rgba(148,163,184,.25);white-space:nowrap}.role-badge.admin{background:#8b5cf626;color:#a78bfa;border-color:#8b5cf64d}.reset-row td{background:#8b5cf60a;border-bottom:1px solid rgba(139,92,246,.15)}.reset-form{display:flex;gap:.5rem;align-items:center;padding:.5rem 0;flex-wrap:wrap}.reset-form .input-field{flex:1;min-width:200px;padding:.4rem .7rem;font-size:.88rem}:root{--bg-app: #0f172a;--bg-card: #1e293b;--bg-card-hover: #334155;--text-primary: #f8fafc;--text-secondary: #94a3b8;--text-muted: #64748b;--primary: #8b5cf6;--primary-hover: #7c3aed;--primary-glow: rgba(139, 92, 246, .5);--success: #10b981;--warning: #f59e0b;--danger: #ef4444;--border-color: #334155;--radius: 12px;--font-main: "Inter", system-ui, Avenir, Helvetica, Arial, sans-serif}body{margin:0;display:flex;place-items:center;min-width:320px;min-height:100vh;background-color:var(--bg-app);color:var(--text-primary);font-family:var(--font-main);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}#root{width:100%;height:100vh;display:flex;flex-direction:column}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:var(--bg-app)}::-webkit-scrollbar-thumb{background:var(--bg-card);border-radius:4px}::-webkit-scrollbar-thumb:hover{background:var(--text-muted)}.container{max-width:1200px;margin:0 auto;padding:2rem;width:100%}.card{background:var(--bg-card);border-radius:var(--radius);padding:1.5rem;box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f;border:1px solid var(--border-color);transition:transform .2s,box-shadow .2s}.btn{border-radius:8px;padding:.6em 1.2em;font-size:1em;font-weight:500;font-family:inherit;background-color:var(--bg-card-hover);color:var(--text-primary);border:1px solid transparent;cursor:pointer;transition:all .25s;display:inline-flex;align-items:center;gap:.5rem}.btn:hover{border-color:var(--primary);background-color:var(--bg-card-hover)}.btn:focus,.btn:focus-visible{outline:4px auto -webkit-focus-ring-color}.btn-primary{background-color:var(--primary);color:#fff}.btn-primary:hover{background-color:var(--primary-hover);box-shadow:0 0 15px var(--primary-glow);transform:translateY(-1px)}.input-field{padding:.8rem 1rem;border-radius:8px;border:1px solid var(--border-color);background:var(--bg-app);color:var(--text-primary);font-size:1rem;width:100%;box-sizing:border-box;transition:border-color .2s}.input-field:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 2px var(--primary-glow)}.glass-panel{background:#1e293bb3;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.1)}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.animate-fade-in{animation:fadeIn .4s ease-out forwards}
