:root{--font-family: "Malgun Gothic", "맑은 고딕", "Noto Sans KR", -apple-system, BlinkMacSystemFont, system-ui, sans-serif;--radius: 14px;--radius-sm: 10px;--radius-md: 12px;--radius-lg: 16px;--success: #28a745;--warning: #ffc107;--error: #dc3545;--info: #17a2b8}:root,:root[data-theme=dark]{color-scheme:dark;--primary: #ff7a18;--primary-light: #ff9a3d;--primary-dark: #e86a12;--primary-rgb: 255 122 24;--secondary: #3b82f6;--secondary-light: #60a5fa;--secondary-rgb: 59 130 246;--accent: #22c55e;--accent-light: #4ade80;--bg-primary: #0b0f15;--bg-secondary: #0e1520;--bg-card: #121a25;--bg-hover: #172335;--bg-dark: #070a0f;--surface-1: rgba(255, 255, 255, .04);--surface-2: rgba(255, 255, 255, .07);--field-bg: rgba(255, 255, 255, .04);--panel-bg: linear-gradient(180deg, rgba(20, 24, 33, .92), rgba(11, 15, 21, .92));--topbar-bg: rgba(20, 24, 33, .72);--menu-bg: rgba(9, 12, 18, .98);--soft-bg: rgba(255, 255, 255, .03);--text-primary: #e5e7eb;--text-secondary: #a8b0bf;--text-muted: #7b8496;--text-light: #ffffff;--border: rgba(148, 163, 184, .18);--border-light: rgba(148, 163, 184, .12);--shadow: 0 12px 28px rgba(0, 0, 0, .32);--shadow-hover: 0 18px 44px rgba(0, 0, 0, .42);--shadow-sm: 0 10px 22px rgba(0, 0, 0, .22)}:root[data-theme=light]{color-scheme:light;--primary: #f97316;--primary-light: #fb923c;--primary-dark: #ea580c;--primary-rgb: 249 115 22;--secondary: #2563eb;--secondary-light: #60a5fa;--secondary-rgb: 37 99 235;--accent: #16a34a;--accent-light: #22c55e;--bg-primary: #f6f8fb;--bg-secondary: #eef2f7;--bg-card: #ffffff;--bg-hover: #f1f5f9;--bg-dark: #e2e8f0;--surface-1: rgba(15, 23, 42, .04);--surface-2: rgba(15, 23, 42, .06);--field-bg: rgba(15, 23, 42, .04);--panel-bg: linear-gradient(180deg, rgba(255, 255, 255, .92), rgba(246, 248, 251, .92));--topbar-bg: rgba(255, 255, 255, .72);--menu-bg: rgba(255, 255, 255, .98);--soft-bg: rgba(15, 23, 42, .03);--text-primary: #0f172a;--text-secondary: #334155;--text-muted: #64748b;--text-light: #ffffff;--border: rgba(15, 23, 42, .12);--border-light: rgba(15, 23, 42, .08);--shadow: 0 12px 28px rgba(2, 6, 23, .08);--shadow-hover: 0 18px 44px rgba(2, 6, 23, .12);--shadow-sm: 0 10px 24px rgba(2, 6, 23, .06)}:root[data-theme=green]{color-scheme:light;--primary: #2fae6a;--primary-light: #6ddba5;--primary-dark: #1f7e4d;--primary-rgb: 47 174 106;--secondary: #2563eb;--secondary-light: #60a5fa;--secondary-rgb: 37 99 235;--accent: #10b981;--accent-light: #34d399;--bg-primary: #f3fbf6;--bg-secondary: #ecf7f0;--bg-card: #ffffff;--bg-hover: #e3f3ea;--bg-dark: #d8efe2;--surface-1: rgba(20, 83, 45, .05);--surface-2: rgba(20, 83, 45, .08);--field-bg: rgba(20, 83, 45, .04);--panel-bg: linear-gradient(180deg, rgba(255, 255, 255, .92), rgba(243, 251, 246, .92));--topbar-bg: rgba(243, 251, 246, .78);--menu-bg: rgba(255, 255, 255, .98);--soft-bg: rgba(20, 83, 45, .04);--text-primary: #0f1f14;--text-secondary: #2f4a39;--text-muted: #6a8a78;--text-light: #ffffff;--border: rgba(20, 83, 45, .14);--border-light: rgba(20, 83, 45, .1);--shadow: 0 12px 28px rgba(2, 6, 23, .08);--shadow-hover: 0 18px 44px rgba(2, 6, 23, .12);--shadow-sm: 0 10px 24px rgba(2, 6, 23, .06)}*{margin:0;padding:0;box-sizing:border-box}body{font-family:var(--font-family);background:var(--bg-primary);color:var(--text-primary);line-height:1.6;min-height:100vh}::-webkit-scrollbar{width:10px}::-webkit-scrollbar-track{background:var(--bg-primary)}::-webkit-scrollbar-thumb{background:rgb(var(--primary-rgb) / .35);border-radius:5px}::-webkit-scrollbar-thumb:hover{background:rgb(var(--primary-rgb) / .55)}.container{max-width:1200px;margin:0 auto;padding:0 20px}.btn{padding:10px 16px;border:none;border-radius:var(--radius-sm);font-family:var(--font-family);font-size:14px;font-weight:500;cursor:pointer;transition:all .3s ease;display:inline-flex;align-items:center;gap:8px}.btn-primary{background:linear-gradient(135deg,var(--primary),var(--primary-light));color:#fff;box-shadow:var(--shadow)}.btn-primary:hover{transform:translateY(-2px);box-shadow:var(--shadow-hover)}.btn-secondary{background:var(--surface-1);color:var(--text-primary);border:1px solid var(--border)}.btn-secondary:hover{background:var(--surface-2);border-color:rgb(var(--primary-rgb) / .35)}.card{background:var(--bg-card);border-radius:var(--radius);padding:20px;box-shadow:var(--shadow);transition:all .3s ease}.card:hover{transform:translateY(-2px);box-shadow:var(--shadow-hover)}.badge{padding:4px 12px;border-radius:12px;font-size:12px;font-weight:600;display:inline-block}.badge-new{background:var(--accent);color:var(--text-primary)}.badge-hot{background:var(--primary);color:#fff}.badge-member{background:var(--secondary);color:#fff}.badge-adult{background:var(--error);color:#fff}input,textarea{width:100%;padding:12px 16px;border:1px solid var(--border);border-radius:var(--radius-sm);font-family:var(--font-family);font-size:14px;transition:all .3s ease;background:var(--field-bg);color:var(--text-primary)}input:focus,textarea:focus{outline:none;border-color:rgb(var(--primary-rgb) / .6);box-shadow:0 0 0 4px rgb(var(--primary-rgb) / .15)}@keyframes bounce{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}.loading{animation:bounce 1s infinite}@keyframes heart-beat{0%,to{transform:scale(1)}25%{transform:scale(1.2)}50%{transform:scale(1.1)}}.heart-beat{animation:heart-beat .5s ease}.hover-lift{transition:transform .3s ease}.hover-lift:hover{transform:translateY(-4px)}.grid{display:grid;gap:20px}.grid-2{grid-template-columns:repeat(2,1fr)}.grid-3{grid-template-columns:repeat(3,1fr)}.grid-4{grid-template-columns:repeat(4,1fr)}@media(max-width:1024px){.grid-4{grid-template-columns:repeat(3,1fr)}}@media(max-width:768px){.grid-3,.grid-4{grid-template-columns:repeat(2,1fr)}}@media(max-width:480px){.grid-2,.grid-3,.grid-4{grid-template-columns:1fr}}.app-modal-backdrop{position:fixed;inset:0;z-index:1200;display:flex;align-items:center;justify-content:center;padding:18px;background:#080b127a}.app-modal{width:min(92vw,var(--app-modal-width, 420px));border-radius:16px;border:1px solid var(--border);background:var(--bg-card);box-shadow:0 10px 28px #00000047;padding:14px;display:grid;gap:12px;animation:appModalIn .1s ease-out}.app-modal-header{display:flex;align-items:center;justify-content:space-between;gap:10px}.app-modal-header h4{margin:0;color:var(--text-primary);font-size:21px;font-weight:900;letter-spacing:-.01em}.app-modal-close{border:0;background:transparent;color:var(--text-secondary);font-size:28px;line-height:1;cursor:pointer;padding:2px 6px;border-radius:8px}.app-modal-close:hover{background:var(--surface-2);color:var(--text-primary)}.app-modal-body{color:var(--text-secondary);font-size:14px;line-height:1.6;display:grid;gap:10px}.app-modal-actions{display:flex;align-items:center;justify-content:flex-end;gap:8px}@keyframes appModalIn{0%{transform:translateY(8px) scale(.98);opacity:0}to{transform:translateY(0) scale(1);opacity:1}}@media(max-width:640px){.app-modal{width:100%}}.app-shell{--shell-gap: 22px;display:grid;grid-template-columns:240px minmax(0,1fr) 320px;gap:var(--shell-gap);padding:18px;max-width:1600px;margin:0 auto}.sidebar,.rightbar{position:sticky;top:18px;align-self:start;height:calc(100vh - 36px);overflow:auto;background:var(--panel-bg);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);padding:16px}.sidebar-brand{display:flex;align-items:center;gap:10px;text-decoration:none;color:var(--text-primary);font-weight:900;letter-spacing:1px;margin-bottom:16px}.sidebar-brand-mark{width:34px;height:34px;display:inline-flex;align-items:center;justify-content:center;border-radius:12px;background:rgb(var(--primary-rgb) / .16);border:1px solid rgb(var(--primary-rgb) / .35)}.sidebar-brand-text{font-size:18px}.sidebar-user{margin:10px 0 18px;padding:12px;border-radius:var(--radius-lg);border:1px solid var(--border);background:var(--soft-bg);box-shadow:var(--shadow-sm)}.sidebar-user-top{display:flex;align-items:center;gap:10px}.sidebar-user-avatar{width:40px;height:40px;border-radius:999px;overflow:hidden;display:inline-flex;align-items:center;justify-content:center;font-weight:900;color:var(--text-primary);background:rgb(var(--primary-rgb) / .16);border:1px solid rgb(var(--primary-rgb) / .35)}.sidebar-user-avatar img{width:100%;height:100%;object-fit:cover}.sidebar-user-meta{flex:1;min-width:0}.sidebar-user-name{font-weight:900;color:var(--text-primary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.sidebar-user-level{margin-top:2px;font-size:12px;font-weight:800;color:var(--text-muted)}.sidebar-user-admin{font-size:11px;font-weight:900;color:rgb(var(--primary-rgb) / .95);padding:4px 8px;border-radius:999px;border:1px solid rgb(var(--primary-rgb) / .35);background:rgb(var(--primary-rgb) / .12)}.sidebar-user-exp{margin-top:10px}.sidebar-user-exp-bar{height:8px;border-radius:999px;background:var(--surface-1);border:1px solid var(--border-light);overflow:hidden}.sidebar-user-exp-fill{height:100%;background:linear-gradient(90deg,var(--accent),rgb(var(--primary-rgb) / .9))}.sidebar-user-exp-text{margin-top:6px;font-size:12px;font-weight:800;color:var(--text-secondary)}.sidebar-user-links{margin-top:12px;display:grid;grid-template-columns:1fr;gap:8px}.sidebar-user-btn{display:inline-flex;justify-content:center;align-items:center;padding:10px 12px;border-radius:14px;border:1px solid var(--border);background:var(--surface-1);color:var(--text-primary);text-decoration:none;font-weight:900;cursor:pointer;transition:background .2s ease,border-color .2s ease,transform .2s ease}.sidebar-user-btn:hover{background:var(--surface-2);border-color:rgb(var(--primary-rgb) / .35);transform:translateY(-1px)}.sidebar-user-btn:disabled{cursor:not-allowed;opacity:.6;transform:none}.sidebar-section{margin-top:18px}.sidebar-section-title{font-size:12px;color:var(--text-muted);margin-bottom:8px;letter-spacing:.6px}.sidebar-link{display:flex;align-items:center;gap:10px;padding:10px 12px;border-radius:14px;text-decoration:none;color:var(--text-primary);border:1px solid transparent;transition:background .2s ease,border-color .2s ease,transform .2s ease}.sidebar-link:hover{background:var(--bg-hover);border-color:var(--border-light);transform:translateY(-1px)}.sidebar-link.active{background:rgb(var(--primary-rgb) / .12);border-color:rgb(var(--primary-rgb) / .35)}.sidebar-icon{width:24px;display:inline-flex;justify-content:center}.sidebar-link-text{flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.sidebar-loading{color:var(--text-secondary);font-size:13px;padding:8px 4px}.sidebar-badge{font-size:11px;font-weight:700;padding:2px 8px;border-radius:999px;border:1px solid var(--border);background:var(--surface-1);color:var(--text-secondary)}.sidebar-badge.badge-19{border-color:#dc354559;background:#dc35451f;color:#ffb4bc}.sidebar-badge.badge-member{border-color:rgb(var(--secondary-rgb) / .35);background:rgb(var(--secondary-rgb) / .12);color:#b7d3ff}.main{min-width:0}.topbar{position:sticky;top:18px;z-index:20;display:flex;align-items:center;justify-content:space-between;gap:14px;padding:12px 14px;border-radius:var(--radius-lg);border:1px solid var(--border);background:var(--topbar-bg);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);box-shadow:var(--shadow-sm)}.topbar-search{position:relative;flex:1;display:flex;align-items:center;gap:10px;padding:10px 12px;border-radius:999px;border:1px solid var(--border);background:var(--field-bg)}.topbar-search-icon{color:var(--text-secondary);font-size:14px}.topbar-search input{all:unset;flex:1;font-size:14px;color:var(--text-primary)}.topbar-search input::placeholder{color:var(--text-muted)}.topbar-search-clear{border:0;background:transparent;color:var(--text-secondary);cursor:pointer;padding:6px;border-radius:10px}.topbar-search-clear:hover{background:var(--surface-2)}.topbar-search-submit{border:1px solid var(--border);background:var(--surface-1);color:var(--text-primary);cursor:pointer;padding:7px 12px;border-radius:12px;font-size:12px;font-weight:900;white-space:nowrap}.topbar-search-submit:hover{background:var(--surface-2);border-color:rgb(var(--primary-rgb) / .35)}.topbar-actions{display:flex;align-items:center;gap:10px}.topbar-upload{padding:10px 14px;border-radius:14px}.topbar-icon-btn{width:40px;height:40px;border-radius:14px;border:1px solid var(--border);background:var(--surface-1);color:var(--text-primary);cursor:pointer;transition:background .2s ease,border-color .2s ease}.topbar-icon-btn:hover{background:var(--surface-2);border-color:rgb(var(--primary-rgb) / .35)}.topbar-user{position:relative}.topbar-auth{display:flex;align-items:center;gap:10px}.topbar-auth-btn{padding:10px 12px;border-radius:14px;font-weight:900;white-space:nowrap}.topbar-auth-btn.highlight{border-color:rgb(var(--primary-rgb) / .35)}.topbar-auth-btn.highlight:hover{border-color:rgb(var(--primary-rgb) / .55)}.topbar-theme{position:relative}.theme-menu{position:absolute;right:0;margin-top:10px;min-width:160px;background:var(--menu-bg);border:1px solid var(--border);border-radius:16px;box-shadow:var(--shadow);overflow:hidden;z-index:30}.theme-item{width:100%;display:flex;align-items:center;gap:10px;padding:12px 14px;border:0;background:transparent;color:var(--text-primary);cursor:pointer;text-align:left;font-weight:800}.theme-item:hover{background:var(--surface-2)}.theme-item.active{background:rgb(var(--primary-rgb) / .12)}.theme-icon{width:24px;display:inline-flex;justify-content:center}.theme-label{flex:1}.topbar-avatar{width:40px;height:40px;display:inline-flex;align-items:center;justify-content:center;overflow:hidden;border-radius:999px;border:1px solid rgb(var(--primary-rgb) / .4);background:rgb(var(--primary-rgb) / .16);color:var(--text-primary);font-weight:800;cursor:pointer}.topbar-avatar img{width:100%;height:100%;object-fit:cover}.topbar-user-menu{position:absolute;right:0;margin-top:10px;min-width:180px;background:var(--menu-bg);border:1px solid var(--border);border-radius:16px;box-shadow:var(--shadow);overflow:hidden}.topbar-user-meta{padding:12px 14px;border-bottom:1px solid var(--border-light)}.topbar-user-name{font-weight:800;color:var(--text-primary)}.topbar-user-badge{margin-top:4px;font-size:12px;color:rgb(var(--primary-rgb) / .95)}.topbar-user-item{display:block;width:100%;text-align:left;padding:12px 14px;border:0;background:transparent;color:var(--text-primary);cursor:pointer;text-decoration:none}.topbar-user-item:hover{background:var(--surface-2)}.topbar-user-item:disabled{cursor:not-allowed;opacity:.6}.topbar-user-item.danger{color:#ffb4bc}.feed-tabs{margin-top:14px;padding:10px;display:flex;justify-content:space-between;align-items:center;border-radius:var(--radius-lg);border:1px solid var(--border);background:var(--soft-bg)}.feed-tabs-left{display:flex;gap:8px;flex-wrap:wrap}.feed-tab{border:1px solid transparent;background:transparent;color:var(--text-secondary);padding:10px 12px;border-radius:999px;cursor:pointer;transition:background .2s ease,color .2s ease,border-color .2s ease;font-weight:700;display:inline-flex;align-items:center;gap:8px}.feed-tab:hover{background:var(--surface-2);color:var(--text-primary)}.feed-tab.active{background:rgb(var(--primary-rgb) / .14);border-color:rgb(var(--primary-rgb) / .35);color:var(--text-primary)}.feed-tab-icon{opacity:.95}.feed-tabs-right{color:var(--text-secondary);font-size:12px;font-weight:700}.content{padding:16px 0 60px}.rightbar-card{background:var(--soft-bg);border:1px solid var(--border);border-radius:var(--radius-lg);padding:16px;box-shadow:var(--shadow-sm)}.rightbar-card+.rightbar-card{margin-top:14px}.rightbar-title{font-weight:900;color:var(--text-primary);margin-bottom:10px}.rightbar-list{margin:0;padding-left:18px;color:var(--text-secondary)}.rightbar-list li{margin:10px 0;list-style:none;display:flex;align-items:center;gap:10px}.rightbar-post-link{flex:1;min-width:0;display:flex;flex-direction:column;gap:4px;text-decoration:none;color:inherit;padding:10px 12px;border-radius:14px;border:1px solid transparent;background:var(--surface-1)}.rightbar-post-link:hover{background:var(--surface-2);border-color:var(--border-light)}.rightbar-post-title{color:var(--text-primary);font-weight:900;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.rightbar-post-meta{color:var(--text-muted);font-size:12px;font-weight:800;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.rightbar-empty{color:var(--text-muted);font-size:13px;font-weight:700;padding:10px 2px}.rightbar-rank{color:rgb(var(--primary-rgb) / .85);font-weight:900}.rightbar-notice{display:flex;flex-direction:column;gap:10px}.rightbar-notice-item{text-decoration:none;color:var(--text-secondary);padding:10px 12px;border-radius:14px;border:1px solid transparent;background:var(--surface-1)}.rightbar-notice-item:hover{background:var(--surface-2);border-color:var(--border-light);color:var(--text-primary)}.rightbar-notice-item.muted{opacity:.8;cursor:default}.top-fab{margin-top:14px;width:100%;padding:12px 14px;border-radius:16px;border:1px solid rgb(var(--primary-rgb) / .35);background:rgb(var(--primary-rgb) / .14);color:var(--text-primary);cursor:pointer;font-weight:900;position:sticky;bottom:18px}.top-fab:hover{background:rgb(var(--primary-rgb) / .22)}@media(max-width:1200px){.app-shell{grid-template-columns:240px minmax(0,1fr)}.rightbar{display:none}}@media(max-width:860px){.app-shell{grid-template-columns:76px minmax(0,1fr)}.sidebar{padding:12px}.sidebar-user,.sidebar-brand-text,.sidebar-section-title,.sidebar-link-text,.sidebar-badge{display:none}.sidebar-link{justify-content:center}.sidebar-icon{width:auto}}@media(max-width:600px){.app-shell{grid-template-columns:1fr;padding:12px}.sidebar{display:none}}.post-card{position:relative;background:var(--bg-card);border-radius:var(--radius-lg);overflow:hidden;cursor:pointer;box-shadow:var(--shadow-sm);text-decoration:none;color:inherit;display:block;border:1px solid var(--border);transition:transform .2s ease,box-shadow .2s ease,border-color .2s ease}.post-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-hover);border-color:rgb(var(--primary-rgb) / .35)}.post-media{position:relative;width:100%;aspect-ratio:4 / 3;overflow:hidden;background:var(--bg-dark)}.post-media img,.post-media video{width:100%;height:100%;object-fit:cover;display:block;transform:scale(1);transition:transform .35s ease}.post-card:hover .post-media img,.post-card:hover .post-media video{transform:scale(1.06)}.post-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;color:#9aa4b2e6;font-weight:900;letter-spacing:1.6px;background:radial-gradient(circle at 18% 22%,rgb(var(--primary-rgb) / .18),transparent 55%),radial-gradient(circle at 82% 78%,rgba(59,130,246,.14),transparent 60%),linear-gradient(135deg,#ffffff0a,#ffffff05)}.post-overlay{position:absolute;left:0;right:0;bottom:0;padding:16px;background:linear-gradient(180deg,#0000,#0000008c 52%,#000000c7)}.post-title{font-size:16px;font-weight:900;margin:0 0 10px;line-height:1.3;color:#fff;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;text-shadow:0 1px 8px rgba(0,0,0,.55)}.post-meta{display:flex;gap:14px;font-size:13px;color:#e5e7ebeb;font-weight:800}.post-meta span{display:flex;align-items:center;gap:6px;text-shadow:0 1px 8px rgba(0,0,0,.45)}@media(max-width:480px){.post-overlay{padding:14px}.post-title{font-size:15px}}.post-grid{margin-bottom:40px}.loading-container{display:flex;justify-content:center;align-items:center;min-height:400px}.loading-container .loading{font-size:18px;color:var(--primary);font-weight:600}.empty-state{text-align:center;padding:80px 20px;color:var(--text-secondary)}.empty-emoji{font-size:64px;display:block;margin-bottom:16px}.empty-state p{font-size:16px;margin:0}.feed-header{display:flex;justify-content:space-between;align-items:flex-end;gap:14px;margin-bottom:18px}.feed-title{font-size:24px;font-weight:900;margin:0 0 6px;color:var(--text-primary);letter-spacing:-.2px}.feed-chip{padding:8px 12px;border-radius:999px;border:1px solid rgb(var(--primary-rgb) / .35);background:rgb(var(--primary-rgb) / .12);color:var(--text-primary);font-size:13px;font-weight:800;max-width:50%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.loading-more,.end-message{text-align:center;margin:16px 0;color:var(--text-secondary);font-weight:700}.end-message{color:var(--text-muted)}.error-message{margin:0 0 14px;padding:12px 14px;border-radius:var(--radius-md);border:1px solid rgba(220,53,69,.35);background:#dc35451f;color:#ffb4bc;font-weight:800}.page-header{margin-bottom:32px;padding-bottom:16px;border-bottom:3px solid var(--border)}.page-header h2{font-size:28px;font-weight:700;margin:0 0 8px;color:var(--text-primary)}.text-secondary{color:var(--text-secondary);font-size:14px;margin:0}.pagination{display:flex;justify-content:center;align-items:center;gap:20px;margin:40px 0}.page-info{font-size:16px;font-weight:600;color:var(--text-primary);min-width:80px;text-align:center}.pagination button:disabled{opacity:.5;cursor:not-allowed}.post-detail{max-width:800px;margin:0 auto;background:var(--bg-card);border-radius:var(--radius-md);padding:30px;box-shadow:var(--shadow-sm)}.post-header{border-bottom:2px solid var(--border);padding-bottom:20px;margin-bottom:30px}.post-header h1{font-size:28px;font-weight:700;margin-bottom:15px;color:var(--text-primary);line-height:1.3}.post-meta{display:flex;gap:10px;font-size:14px;color:var(--text-secondary)}.post-author-link{color:var(--text-primary);font-weight:900;text-decoration:none}.post-author-link:hover{text-decoration:underline}.post-content{font-size:16px;line-height:1.8;color:var(--text-primary);margin-bottom:30px}.post-content p{margin-bottom:15px;white-space:pre-wrap}.post-images{display:flex;flex-direction:column;gap:15px;margin-top:20px}.post-images img{width:100%;height:auto;border-radius:var(--radius-sm);box-shadow:var(--shadow-sm)}.post-actions{display:flex;gap:10px;padding-top:20px;border-top:1px solid var(--border)}.post-comments{margin-top:26px;padding-top:22px;border-top:1px solid var(--border)}.post-comments-header{display:flex;align-items:center;gap:10px;margin-bottom:12px}.post-comments-header h3{font-size:18px;font-weight:900;color:var(--text-primary)}.post-comments-count{font-size:12px;font-weight:900;color:var(--text-secondary);padding:4px 10px;border-radius:999px;border:1px solid var(--border);background:var(--surface-1)}.post-comment-form{display:grid;gap:10px;margin-bottom:18px}.post-comment-media-tools{display:flex;align-items:center;gap:10px;flex-wrap:wrap}.post-comment-media-button{position:relative;overflow:hidden}.post-comment-media-input{position:absolute;inset:0;opacity:0;cursor:pointer}.post-comment-media-limit{font-size:12px;color:var(--text-muted);font-weight:700}.post-comment-media-picked{display:flex;align-items:center;justify-content:space-between;gap:10px;border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--surface-1);padding:8px 10px;font-size:12px;color:var(--text-secondary)}.post-comment-media-picked span{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.post-comment-media-remove{border:0;background:transparent;color:#ffb4bc;font-size:12px;font-weight:800;cursor:pointer;padding:4px 6px;border-radius:8px}.post-comment-media-remove:hover{background:#dc35451f}.post-comment-form textarea{width:100%;border-radius:var(--radius-md);border:1px solid var(--border);background:var(--field-bg);color:var(--text-primary);padding:12px 14px;resize:vertical;min-height:90px;font-family:var(--font-family)}.post-comment-list{display:grid;gap:10px}.post-comment-block{display:grid;gap:8px}.post-comment{border-radius:var(--radius-md);border:1px solid var(--border);background:var(--soft-bg);padding:12px 14px}.post-comment-top{display:flex;align-items:center;gap:10px}.post-comment-author{font-weight:900;color:var(--text-primary);text-decoration:none;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.post-comment-date{margin-left:auto;font-size:12px;font-weight:800;color:var(--text-muted);white-space:nowrap}.post-comment-delete{border:0;background:transparent;color:#ffb4bc;font-weight:900;cursor:pointer;padding:6px 10px;border-radius:10px}.post-comment-delete:hover{background:#dc35451f}.post-comment-reply{border:0;background:transparent;color:var(--text-secondary);font-weight:900;cursor:pointer;padding:6px 10px;border-radius:10px}.post-comment-reply:hover{background:var(--surface-2)}.post-comment-body{margin-top:10px;color:var(--text-primary);white-space:pre-wrap;line-height:1.7}.post-comment-media-list{margin-top:10px;display:grid;gap:8px}.post-comment-media{width:min(100%,420px);border-radius:var(--radius-sm);border:1px solid var(--border);background:var(--field-bg)}.post-reply-form{margin-left:18px;border-left:2px solid var(--border);padding-left:10px;display:grid;gap:8px}.post-reply-form textarea{width:100%;border-radius:var(--radius-md);border:1px solid var(--border);background:var(--field-bg);color:var(--text-primary);padding:10px 12px;resize:vertical;min-height:72px;font-family:var(--font-family)}.post-reply-list{margin-left:18px;border-left:2px solid var(--border);padding-left:10px;display:grid;gap:8px}.post-reply-item{border-radius:var(--radius-md);border:1px solid var(--border);background:var(--surface-1);padding:10px 12px}.post-reply-top{display:flex;align-items:center;gap:10px}.loading-container,.error-message{text-align:center;padding:60px 20px;font-size:16px;color:var(--text-secondary)}.error-message{color:#ffb4bc;background:#dc35451f;border:1px solid rgba(220,53,69,.35);border-radius:var(--radius-md);font-weight:800}.post-modal-danger{border-color:#ff637a6b;background:#cf4a66;box-shadow:none}.post-modal-danger:hover{filter:none;opacity:.94}.action-toast{position:fixed;top:22px;right:22px;z-index:1300;min-width:220px;max-width:min(92vw,360px);border-radius:12px;padding:12px 14px;font-size:14px;font-weight:900;line-height:1.4;box-shadow:0 10px 22px #0000003d;animation:actionToastIn .18s ease-out}.action-toast.success{border:1px solid rgba(53,201,138,.42);background:linear-gradient(135deg,#28a070f2,#1e7e59f2);color:#f3fff8}.action-toast.error{border:1px solid rgba(255,117,132,.48);background:linear-gradient(135deg,#c7455cf2,#a3364af2);color:#fff7f8}@keyframes actionToastIn{0%{transform:translateY(-10px);opacity:0}to{transform:translateY(0);opacity:1}}@media(max-width:640px){.action-toast{inset:auto 12px 14px;max-width:none}}.upload-page{display:flex;justify-content:center}.upload-card{width:100%;max-width:860px;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);padding:22px}.upload-header{margin-bottom:18px}.upload-error{margin:0 0 14px;padding:12px 14px;border-radius:var(--radius-md);border:1px solid rgba(220,53,69,.35);background:#dc35451f;color:#ffb4bc;font-weight:900}.upload-title{font-size:24px;font-weight:900;margin:0 0 6px;color:var(--text-primary)}.upload-form{display:flex;flex-direction:column;gap:16px}.upload-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px}.upload-field label{display:block;font-size:13px;font-weight:800;color:var(--text-secondary);margin:0 0 8px 2px}.upload-field select{width:100%;padding:12px 16px;border:1px solid var(--border);border-radius:var(--radius-sm);font-family:var(--font-family);font-size:14px;background:var(--field-bg);color:var(--text-primary)}.upload-field select:focus{outline:none;border-color:rgb(var(--primary-rgb) / .6);box-shadow:0 0 0 4px rgb(var(--primary-rgb) / .15)}.upload-hint{margin-top:8px;font-size:12px;color:var(--text-muted)}.upload-hint.warn{color:#ffb4bc}.upload-files{margin-top:10px;display:flex;flex-direction:column;gap:8px}.upload-file{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:10px 12px;border-radius:14px;border:1px solid var(--border-light);background:var(--soft-bg)}.upload-file-name{flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-weight:800;color:var(--text-primary)}.upload-file-size{font-size:12px;color:var(--text-secondary);font-weight:800}.upload-actions{display:flex;justify-content:flex-end;gap:10px;margin-top:6px}@media(max-width:720px){.upload-grid{grid-template-columns:1fr}}.auth-page{min-height:100vh;display:flex;justify-content:center;align-items:center;padding:20px}.auth-container{background:var(--bg-card);border-radius:var(--radius-lg);box-shadow:var(--shadow-hover);padding:40px;width:100%;max-width:440px}.auth-header{text-align:center;margin-bottom:32px}.auth-emoji{font-size:48px;display:block;margin-bottom:16px}.auth-header h1{font-size:28px;font-weight:700;margin:0 0 8px;background:linear-gradient(135deg,var(--primary),var(--primary-light));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.auth-header p{color:var(--text-secondary);margin:0}.auth-form{margin-bottom:24px}.form-group{margin-bottom:20px}.form-group label{display:block;margin-bottom:8px;font-weight:600;font-size:14px;color:var(--text-primary)}.error-message{background:var(--error);color:#fff;padding:12px 16px;border-radius:var(--radius-sm);margin-bottom:20px;font-size:14px}.btn-full{width:100%;justify-content:center;padding:14px;font-size:16px;font-weight:600}.auth-footer{text-align:center;padding-top:20px;border-top:2px solid var(--border)}.auth-footer p{margin:0;color:var(--text-secondary);font-size:14px}.auth-footer a{color:var(--primary);text-decoration:none;font-weight:600}.auth-footer a:hover{text-decoration:underline}.settings-page{max-width:860px;margin:0 auto;display:grid;gap:14px}.settings-hidden-file{display:none}.settings-header h2{margin:0 0 8px;font-size:24px;font-weight:900;color:var(--text-primary)}.settings-header p{margin:0;color:var(--text-secondary);font-size:14px}.settings-alert{border-radius:12px;padding:10px 12px;font-size:14px;font-weight:800}.settings-alert.error{background:#dc35451f;border:1px solid rgba(220,53,69,.35);color:#ffb4bc}.settings-alert.success{background:rgb(var(--secondary-rgb) / .12);border:1px solid rgb(var(--secondary-rgb) / .35);color:var(--text-primary)}.settings-card{border:1px solid var(--border);border-radius:14px;background:var(--bg-card);padding:14px;display:grid;gap:10px}.settings-card h3{margin:0;font-size:16px;font-weight:900;color:var(--text-primary)}.settings-help{margin:0;color:var(--text-secondary);font-size:13px}.settings-card input[type=text]{border-radius:10px;border:1px solid var(--border);background:var(--field-bg);color:var(--text-primary);padding:10px 12px;font-size:14px}.settings-avatar-grid{display:grid;grid-template-columns:1fr;gap:14px}.settings-avatar-panel{border:1px solid var(--border);border-radius:12px;background:var(--soft-bg);padding:12px;display:grid;gap:10px}.settings-avatar-title{color:var(--text-secondary);font-size:12px;font-weight:800}.settings-avatar-current{width:200px;height:200px;max-width:100%;margin:0 auto;border:1px solid var(--border);background:var(--field-bg);display:flex;align-items:center;justify-content:center;overflow:hidden;color:var(--text-muted);font-size:13px;font-weight:700;border-radius:999px}.settings-avatar-current img{width:100%;height:100%;object-fit:cover}.settings-avatar-actions{display:flex;flex-wrap:wrap;gap:8px}.settings-crop-controls{display:grid;gap:8px;border:1px solid var(--border);border-radius:12px;background:var(--soft-bg);padding:10px}.settings-crop-editor-wrap{border:1px solid var(--border);border-radius:12px;background:var(--soft-bg);padding:10px;display:grid;gap:8px}.settings-crop-editor-canvas{width:100%;max-width:320px;aspect-ratio:1 / 1;border-radius:12px;border:1px solid var(--border);background:var(--field-bg);margin:0 auto;display:block;cursor:grab;touch-action:none}.settings-crop-editor-canvas.dragging{cursor:grabbing}.settings-crop-row{display:grid;grid-template-columns:88px minmax(0,1fr);align-items:center;gap:10px;color:var(--text-primary);font-size:13px;font-weight:800}.settings-crop-row input[type=range]{width:100%}.settings-meta{display:flex;flex-wrap:wrap;gap:12px;color:var(--text-muted);font-size:12px;font-weight:700}.settings-toggle{display:grid;grid-template-columns:minmax(0,1fr) auto;align-items:center;gap:16px;color:var(--text-primary);font-weight:800;border:1px solid var(--border);border-radius:10px;background:var(--soft-bg);padding:10px 12px}.settings-toggle span{min-width:0;white-space:nowrap}.settings-toggle input[type=checkbox]{width:18px;height:18px;margin:0;padding:0;border-radius:4px;justify-self:end;flex:0 0 auto}.settings-actions{display:flex;justify-content:flex-end}.settings-editor-modal-body{display:grid;gap:12px}.settings-crop-editor-wrap.modal{border-radius:12px;padding:12px;background:var(--bg-secondary);border-color:var(--border)}.settings-crop-controls.modal{border-radius:12px;background:var(--surface-1);border-color:var(--border)}.settings-crop-controls.modal .settings-crop-row{color:var(--text-primary)}.settings-crop-controls.modal .settings-help{color:var(--text-secondary)}.settings-editor-actions{display:flex;align-items:center;justify-content:space-between;gap:10px}.settings-editor-actions-right{display:flex;align-items:center;gap:8px}@media(max-width:600px){.settings-avatar-current{width:170px;height:170px}.settings-crop-row{grid-template-columns:78px minmax(0,1fr)}.settings-actions{justify-content:stretch}.settings-actions .btn{width:100%}.settings-editor-actions{flex-direction:column;align-items:stretch}.settings-editor-actions-right{width:100%}.settings-editor-actions-right .btn,.settings-editor-actions .btn{flex:1}}.user-profile-page{display:grid;gap:14px}.user-profile-header{display:flex;align-items:center;gap:12px;border:1px solid var(--border);border-radius:14px;background:var(--bg-card);padding:12px}.user-profile-avatar{width:54px;height:54px;border-radius:50%;overflow:hidden;border:1px solid var(--border);background:var(--surface-2);display:flex;align-items:center;justify-content:center;color:var(--text-primary);font-weight:900}.user-profile-avatar img{width:100%;height:100%;object-fit:cover}.user-profile-meta h2{margin:0;font-size:20px;font-weight:900;color:var(--text-primary)}.user-profile-meta p{margin:4px 0 0;color:var(--text-secondary);font-size:13px;font-weight:800}.user-profile-tabs{display:flex;gap:8px}.user-profile-tab{border:1px solid var(--border);background:var(--surface-1);color:var(--text-secondary);border-radius:12px;padding:8px 12px;cursor:pointer;font-weight:900}.user-profile-tab.active{color:var(--text-primary);border-color:rgb(var(--primary-rgb) / .35);background:rgb(var(--primary-rgb) / .14)}.user-profile-denied{border-radius:12px;border:1px solid var(--border);background:var(--surface-1);color:var(--text-secondary);padding:12px 14px;font-size:14px;font-weight:800}.admin-layout{display:flex;min-height:100vh;background:#f5f5f5}.admin-sidebar{width:260px;background:linear-gradient(180deg,#2c3e50,#34495e);color:#fff;position:fixed;height:100vh;overflow-y:auto;box-shadow:2px 0 10px #0000001a}.admin-sidebar-header{padding:25px 20px;border-bottom:1px solid rgba(255,255,255,.1)}.admin-sidebar-header h2{font-size:20px;font-weight:700;margin:0;display:flex;align-items:center;gap:10px}.admin-nav{padding:20px 0}.admin-nav-item{display:flex;align-items:center;gap:12px;padding:14px 20px;color:#fffc;text-decoration:none;transition:all .2s;font-size:15px;border-left:3px solid transparent}.admin-nav-item:hover{background:#ffffff0d;color:#fff}.admin-nav-item.active{background:#ffffff1a;color:#fff;border-left-color:#3498db;font-weight:600}.admin-content{flex:1;margin-left:260px}.admin-topbar{background:#fff;padding:20px 30px;box-shadow:0 2px 4px #0000000d;display:flex;justify-content:space-between;align-items:center}.admin-topbar h1{font-size:24px;font-weight:700;margin:0;color:#2c3e50}.admin-topbar-actions{display:flex;gap:15px;align-items:center}.admin-main{padding:30px}.admin-card{background:#fff;border-radius:8px;padding:25px;box-shadow:0 2px 8px #00000014;margin-bottom:20px}.admin-stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:20px;margin-bottom:30px}.stat-card{background:#fff;border-radius:8px;padding:20px;box-shadow:0 2px 8px #00000014;display:flex;align-items:center;gap:15px;transition:transform .2s}.stat-card:hover{transform:translateY(-2px);box-shadow:0 4px 12px #0000001f}.stat-icon{width:60px;height:60px;border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:28px}.stat-icon.blue{background:linear-gradient(135deg,#667eea,#764ba2)}.stat-icon.green{background:linear-gradient(135deg,#f093fb,#f5576c)}.stat-icon.purple{background:linear-gradient(135deg,#4facfe,#00f2fe)}.stat-icon.orange{background:linear-gradient(135deg,#43e97b,#38f9d7)}.stat-content h3{font-size:14px;color:#7f8c8d;margin:0 0 5px;font-weight:500}.stat-content p{font-size:28px;font-weight:700;margin:0;color:#2c3e50}.admin-table{width:100%;border-collapse:collapse}.admin-table th{background:#f8f9fa;padding:12px;text-align:left;font-weight:600;color:#2c3e50;border-bottom:2px solid #dee2e6}.admin-table td{padding:12px;border-bottom:1px solid #dee2e6}.admin-table tr:hover{background:#f8f9fa}.btn-group{display:flex;gap:8px}.admin-form-group{margin-bottom:20px}.admin-form-group label{display:block;margin-bottom:8px;font-weight:600;color:#2c3e50}.admin-form-group input,.admin-form-group select,.admin-form-group textarea{width:100%;padding:10px;border:1px solid #ddd;border-radius:5px;font-size:14px}.admin-form-group textarea{min-height:120px;resize:vertical}.modal-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000}.modal-content{background:#fff;border-radius:10px;padding:30px;max-width:600px;width:90%;max-height:90vh;overflow-y:auto;box-shadow:0 10px 40px #0003}.modal-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px}.modal-header h3{margin:0;font-size:20px;color:#2c3e50}.close-btn{background:none;border:none;font-size:28px;cursor:pointer;color:#95a5a6;padding:0;width:30px;height:30px;display:flex;align-items:center;justify-content:center}.close-btn:hover{color:#2c3e50}.crawler-page{padding:20px 0;min-height:100vh}.page-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:30px;padding-bottom:20px;border-bottom:3px solid var(--border)}.page-header h1{font-size:28px;font-weight:700;margin:0}.stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;margin-bottom:30px}.stat-card{background:var(--bg-card);padding:20px;border-radius:var(--radius);box-shadow:var(--shadow);text-align:center}.stat-label{font-size:13px;color:var(--text-secondary);margin-bottom:8px}.stat-value{font-size:32px;font-weight:700;color:var(--primary)}.modal-overlay{position:fixed;inset:0;background:#00000080;display:flex;justify-content:center;align-items:center;z-index:1000}.modal-content{background:var(--bg-card);border-radius:var(--radius-lg);box-shadow:0 10px 40px #0000004d;max-width:600px;width:90%;max-height:90vh;overflow-y:auto}.results-modal{max-width:900px;padding:0}.results-header{display:flex;justify-content:space-between;align-items:center;padding:20px 25px;border-bottom:1px solid var(--border)}.results-header h2{margin:0;font-size:20px}.close-btn{background:none;border:none;font-size:28px;cursor:pointer;color:var(--text-secondary);line-height:1}.results-summary{display:flex;gap:20px;padding:15px 25px;background:#f8f9fa;border-bottom:1px solid var(--border);font-size:14px}.success-count{color:#27ae60}.skipped-count{color:#f39c12}.failed-count{color:#e74c3c}.results-list{padding:20px 25px;max-height:400px;overflow-y:auto}.no-results{text-align:center;color:var(--text-secondary);padding:40px 0}.results-table{width:100%;border-collapse:collapse;font-size:13px}.results-table th,.results-table td{padding:10px;text-align:left;border-bottom:1px solid var(--border)}.results-table th{font-weight:600;background:#f8f9fa}.results-table tr.status-success td:first-child{color:#27ae60}.results-table tr.status-skipped td:first-child{color:#f39c12}.results-table tr.status-failed td:first-child{color:#e74c3c}.results-table a{color:var(--primary);text-decoration:none}.results-table a:hover{text-decoration:underline}@media(max-width:1024px){.stats-grid{grid-template-columns:repeat(2,1fr)}}@media(max-width:480px){.stats-grid{grid-template-columns:1fr}.page-header{flex-direction:column;gap:15px;align-items:flex-start}}.campaign-form{padding:30px}.form-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:25px;padding-bottom:20px;border-bottom:2px solid var(--border)}.form-header h2{margin:0;font-size:24px;font-weight:700}.close-btn{background:none;border:none;font-size:32px;color:var(--text-secondary);cursor:pointer;line-height:1;padding:0;width:32px;height:32px}.close-btn:hover{color:var(--text-primary)}.form-section{margin-bottom:25px;padding-bottom:25px;border-bottom:1px solid var(--border-light)}.form-section:last-of-type{border-bottom:none}.form-section h3{font-size:18px;font-weight:600;margin:0 0 15px;color:var(--primary)}.help-text{color:var(--text-secondary);font-size:13px;margin:0 0 15px}.form-group{margin-bottom:16px}.form-group label{display:block;margin-bottom:6px;font-weight:500;font-size:14px}.form-group input[type=text],.form-group input[type=url],.form-group input[type=number],.form-group select{width:100%;padding:10px 14px;border:2px solid var(--border);border-radius:var(--radius-sm);font-size:14px}.form-group input:focus,.form-group select:focus{outline:none;border-color:var(--primary)}.form-group small{display:block;margin-top:4px;font-size:12px;color:var(--text-secondary)}.form-group input[type=checkbox]{margin-right:6px}.form-row{display:grid;grid-template-columns:repeat(2,1fr);gap:15px}.form-actions{display:flex;justify-content:flex-end;gap:10px;margin-top:25px;padding-top:20px;border-top:2px solid var(--border)}@media(max-width:768px){.campaign-form{padding:20px}.form-row{grid-template-columns:1fr}.form-actions{flex-direction:column}.form-actions button{width:100%}}.selector-tips{margin-top:15px;padding:15px;background:var(--bg-hover);border-radius:var(--radius-sm);border-left:3px solid var(--primary)}.selector-tips details{cursor:pointer}.selector-tips summary{font-weight:600;color:var(--primary);-webkit-user-select:none;user-select:none}.selector-tips ul{margin-top:10px;padding-left:20px}.selector-tips li{margin-bottom:6px;font-size:13px}.selector-tips code{background:var(--bg-card);padding:2px 6px;border-radius:3px;font-family:Courier New,monospace;color:var(--error);font-size:12px}.error-message{background:#fee;color:var(--error);padding:12px;border-radius:var(--radius-sm);margin-bottom:15px;border-left:3px solid var(--error)}.campaign-list{margin-top:30px}.campaign-list h2{font-size:20px;font-weight:600;margin-bottom:20px}.campaign-card{background:var(--bg-card);border-radius:var(--radius);padding:20px;margin-bottom:20px;box-shadow:var(--shadow);border-left:4px solid var(--primary)}.campaign-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:15px;padding-bottom:15px;border-bottom:1px solid var(--border)}.campaign-title{display:flex;align-items:center;gap:12px}.campaign-title h3{margin:0;font-size:18px;font-weight:600}.campaign-status{display:flex;gap:8px}.status-badge{padding:4px 10px;border-radius:12px;font-size:12px;font-weight:600}.status-badge.active{background:var(--success);color:#fff}.status-badge.inactive{background:var(--text-muted);color:#fff}.campaign-actions{display:flex;gap:8px;flex-wrap:wrap}.btn-sm{padding:6px 12px;font-size:13px}.btn-danger{background:var(--error);color:#fff}.btn-danger:hover{background:var(--error);opacity:.9}.campaign-info{display:grid;grid-template-columns:repeat(2,1fr);gap:10px}.info-row{display:flex;gap:8px;font-size:14px}.info-row .label{color:var(--text-secondary);font-weight:500;min-width:100px}.info-row .value{color:var(--text-primary)}.info-row .link{color:var(--primary);text-decoration:none;word-break:break-all}.info-row .link:hover{text-decoration:underline}.spinner{display:inline-block;width:12px;height:12px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .8s linear infinite;margin-right:5px;vertical-align:middle}@keyframes spin{to{transform:rotate(360deg)}}.crawling-progress{margin-top:15px;padding-top:15px;border-top:1px solid var(--border)}.progress-bar{width:100%;height:6px;background:#e0e0e0;border-radius:3px;overflow:hidden;margin-bottom:10px}.progress-bar-fill{height:100%;background:linear-gradient(90deg,#3498db,#2ecc71);animation:progress 2s ease-in-out infinite;border-radius:3px}@keyframes progress{0%{width:0%}50%{width:70%}to{width:100%}}.progress-text{font-size:13px;color:var(--text-secondary);text-align:center;margin:0}.btn-info{background:#3498db;color:#fff}.btn-info:hover{background:#2980b9}@media(max-width:768px){.campaign-header{flex-direction:column;gap:15px}.campaign-info{grid-template-columns:1fr}.campaign-actions{width:100%}.campaign-actions button{flex:1}}.crawl-result{margin-top:15px;padding:12px 15px;border-radius:6px;display:flex;align-items:center;gap:10px}.crawl-result.success{background:linear-gradient(135deg,#d4edda,#c3e6cb);border:1px solid #27ae60}.crawl-result.error{background:linear-gradient(135deg,#f8d7da,#f5c6cb);border:1px solid #e74c3c}.result-icon{font-size:18px}.result-text{flex:1;font-size:14px;font-weight:500;color:#2c3e50}.result-close{background:none;border:none;font-size:20px;cursor:pointer;color:#7f8c8d;padding:0;line-height:1}.result-close:hover{color:#2c3e50}
