@import"https://fonts.googleapis.com/css2?family=Space+Grotesk:wght@400;500;600;700&display=swap";:root{font-family:Space Grotesk,Segoe UI,system-ui,-apple-system,sans-serif;color:#0f172a;background-color:#f8fafc;line-height:1.5}*{box-sizing:border-box}body{margin:0;min-height:100vh;background:linear-gradient(135deg,#eef2ff,#f8fafc 40%,#e0f4ff);color:#0f172a}a{color:inherit;text-decoration:none}#root{min-height:100vh}.modal-open{overflow:hidden}.modal-backdrop{position:fixed;inset:0;background:#0f172a59;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);display:grid;place-items:center;padding:20px;z-index:50}.modal-card{width:min(820px,100%);max-height:90vh;overflow:auto;background:#fff;border-radius:20px;padding:24px;box-shadow:0 24px 50px #0f172a40;border:1px solid #e2e8f0}.modal-header{display:flex;justify-content:space-between;gap:12px;align-items:flex-start}.modal-meta{display:flex;gap:8px;align-items:center;margin-top:6px}.modal-body{margin-top:14px;color:#0f172a;line-height:1.7}.modal-footer{margin-top:18px;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:12px}.rating-box{display:flex;align-items:center;gap:6px;background:#f8fafc;padding:8px 12px;border-radius:12px;border:1px solid #e2e8f0}.rating-actions{display:flex;align-items:center;gap:8px}.rating-btn{padding:8px 10px;border-radius:10px;border:1px solid #e2e8f0;background:#fff;cursor:pointer;transition:all .15s ease}.modal-actions{display:flex;align-items:center;gap:8px}.close-btn{border:1px solid #e2e8f0;background:#f8fafc;border-radius:10px;padding:6px 10px;font-size:1rem;cursor:pointer;color:#475569;transition:all .15s ease}.close-btn:hover,.rating-btn:hover{background:#e0f2fe;border-color:#0ea5e9}.comments-block{margin-top:16px;display:flex;flex-direction:column;gap:10px}.comment-item{display:flex;gap:10px;padding:8px 0;border-bottom:1px solid #f1f5f9}.comment-avatar{width:36px;height:36px;border-radius:50%;background:#e2e8f0;display:grid;place-items:center;font-weight:700;color:#0f172a;object-fit:cover}.comment-body{flex:1}.comment-meta{display:flex;gap:6px;align-items:baseline}.comment-form{display:flex;gap:8px;align-items:center}.comment-form input{flex:1}.app-shell{min-height:100vh}.app-header{position:sticky;top:0;z-index:20;display:flex;align-items:center;justify-content:space-between;padding:14px 20px;background:#ffffffe6;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border-bottom:1px solid #e2e8f0;box-shadow:0 6px 16px #0f172a0d}.brand-link{display:flex;align-items:center;gap:12px;color:#0f172a}.brand-logo{height:42px}.nav-links{display:flex;gap:10px;align-items:center}.nav-link{padding:8px 12px;border-radius:10px;color:#475569;font-weight:600;transition:all .15s ease}.nav-link:hover{background:#e2e8f0}.nav-link.active{background:#e0f2fe;color:#0284c7}.header-actions{display:flex;gap:8px;align-items:center}.user-pill{display:flex;align-items:center;gap:6px;padding:6px 10px;min-height:34px;border-radius:12px;background:#fff;border:1px solid #e2e8f0;box-shadow:0 1px 6px #0f172a0f;cursor:pointer;position:relative}.user-avatar{width:24px;height:24px;border-radius:50%;background:linear-gradient(135deg,#0ea5e9,#22d3ee);color:#fff;display:grid;place-items:center;font-weight:800;font-size:.85rem}.user-avatar.photo{object-fit:cover;border:1px solid #e2e8f0}.user-meta{display:flex;flex-direction:column;gap:2px;line-height:1.1}.user-name{font-weight:700;font-size:.88rem}.user-role{font-size:.8rem;color:#64748b}.notif-pill{position:relative;padding:8px 10px;border-radius:14px;border:1px solid #e2e8f0;background:#fff;display:flex;align-items:center;gap:6px;cursor:pointer}.notif-icon{font-size:1.1rem}.notif-badge{background:#ef4444;color:#fff;border-radius:999px;padding:2px 6px;font-size:.75rem;font-weight:700}.notif-dropdown{position:absolute;top:110%;right:0;width:280px;background:#fff;border:1px solid #e2e8f0;border-radius:12px;box-shadow:0 20px 40px #0f172a1f;z-index:40;max-height:340px;overflow:auto}.notif-item{padding:10px 12px;border-bottom:1px solid #f1f5f9}.notif-item:last-child{border-bottom:none}.notif-item.unread{background:#f8fafc}.notif-text{font-weight:600}.notif-time{font-size:.8rem}.profile-popover{position:absolute;top:72px;right:20px;width:320px;background:#fff;border:1px solid #e2e8f0;border-radius:14px;padding:16px;box-shadow:0 18px 36px #0f172a24;z-index:30}.profile-popover h4{margin:0 0 10px}.profile-popover label{display:block;margin-bottom:10px}.profile-popover input{width:100%}.btn{border:none;border-radius:12px;padding:12px 18px;font-weight:700;cursor:pointer;background:linear-gradient(135deg,#0ea5e9,#22d3ee);color:#0f172a;transition:transform .05s ease,box-shadow .15s ease,filter .2s ease,opacity .15s ease}.btn:hover{transform:translateY(-1px);box-shadow:0 10px 22px #0f172a29}.btn:disabled{opacity:.6;cursor:not-allowed;transform:none;box-shadow:none}.btn-primary{background:linear-gradient(135deg,#0ea5e9,#22d3ee);color:#fff;border:none}.btn-ghost{background:transparent;border:1px solid #e2e8f0;color:#0f172a}.btn-ghost:hover{background:#e2e8f0}.btn-danger{background:#ef4444;color:#fff}.btn-sm{padding:8px 12px;font-size:.9rem}.page-content{width:min(1600px,100% - 32px);margin:0 auto;padding:20px 0 32px}.page{display:flex;flex-direction:column;gap:16px}.page-header{display:flex;align-items:center;justify-content:space-between;gap:16px;flex-wrap:wrap}.filter-group{display:flex;gap:12px;flex-wrap:wrap;align-items:center;background:#fff;padding:10px 12px;border-radius:12px;border:1px solid #e2e8f0;box-shadow:0 8px 18px #0f172a0f}.inline-label{display:flex;flex-direction:column;gap:6px;font-size:.9rem;color:#475569}.search-box input,select,input,textarea{border-radius:12px;border:1px solid #e2e8f0;padding:10px 12px;background:#fff;font-family:inherit;font-size:1rem;color:#0f172a;outline:none;transition:border-color .15s ease,box-shadow .15s ease}input:focus,textarea:focus,select:focus{border-color:#0ea5e9;box-shadow:0 0 0 4px #0ea5e926}.search-box input{min-width:240px}.grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:16px}.card{background:#fff;border-radius:16px;padding:16px;border:1px solid #e2e8f0;box-shadow:0 18px 30px #0f172a0f}.post-line{display:grid;grid-template-columns:56px 1fr;gap:10px;align-items:flex-start;padding:10px 12px;border:1px solid #e2e8f0;border-radius:12px;background:#fff;box-shadow:0 6px 14px #0f172a0d;cursor:pointer;transition:transform .08s ease,box-shadow .08s ease}.post-line:hover{transform:translateY(-2px);box-shadow:0 10px 22px #0f172a1a}.post-line-votes{display:flex;align-items:center}.post-line-title{display:flex;align-items:center;gap:10px;flex-wrap:wrap}.post-line-title h3{margin:0;font-size:1.05rem;font-weight:700;line-height:1.3}.post-line-body{display:flex;flex-direction:column;gap:4px}.post-line-meta{display:flex;gap:8px;align-items:center;flex-wrap:wrap}.post-line p{margin:0}.card-header{display:flex;align-items:center;justify-content:space-between;gap:12px}.card-title-row{display:flex;align-items:center;gap:10px;flex-wrap:wrap}.card-footer{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:10px}.meta{display:flex;gap:8px;align-items:center;flex-wrap:wrap}.tag{display:inline-flex;padding:6px 10px;background:#f1f5f9;border-radius:12px;font-size:.9rem;color:#0f172a;border:1px solid #e2e8f0}.tags-row{display:flex;gap:8px;flex-wrap:wrap}.muted{color:#64748b}.underline{text-decoration:underline}.pill{display:inline-flex;align-items:center;gap:6px;padding:6px 10px;border-radius:999px;background:#eef2ff;color:#4338ca;font-weight:600}.status-badge{display:inline-flex;align-items:center;padding:6px 10px;border-radius:999px;font-weight:700;font-size:.85rem}.vote-button{display:inline-flex;align-items:center;gap:8px;padding:8px 12px;border-radius:12px;border:1px solid #e2e8f0;background:#fff;color:#0f172a;cursor:pointer;transition:all .1s ease}.vote-button:hover{background:#e0f2fe;border-color:#bae6fd}.vote-button.active{background:#0ea5e9;color:#fff;border-color:#0284c7}.vote-icon,.vote-count{font-weight:700}.pagination{display:flex;align-items:center;justify-content:space-between;padding:12px 0}.empty{padding:20px;text-align:center;border:1px dashed #cbd5e1;border-radius:14px;background:#f8fafc}.kanban-wrapper{padding-bottom:12px;padding-top:4px;overflow-x:hidden}.kanban-grid{display:grid;grid-template-columns:repeat(6,minmax(200px,1fr));gap:18px;width:100%;max-width:100%;margin:0 auto}.kanban-column{border:1px solid #e2e8f0;border-radius:16px;background:#fff;background-image:linear-gradient(180deg,#e2e8f059,#fff0 60%);min-height:200px;display:flex;flex-direction:column;box-shadow:0 16px 32px #0f172a1a}.kanban-column-header{display:flex;align-items:center;gap:8px;padding:14px;font-weight:700;border-bottom:1px solid #e2e8f0;letter-spacing:.01em;text-transform:none;white-space:nowrap}.kanban-column-body{padding:10px;display:flex;flex-direction:column;gap:12px;min-height:180px}.kanban-column-body.dragging-over{background:linear-gradient(180deg,#e0f2fe,#f8fafc)}.dot{width:10px;height:10px;border-radius:50%;display:inline-block}.kanban-card{background:#fff;border:1px solid #e2e8f0;border-radius:12px;padding:10px 12px;box-shadow:0 4px 10px #0f172a14;cursor:grab;transition:transform .1s ease,box-shadow .1s ease;min-height:auto;display:flex;flex-direction:column;gap:6px;overflow:hidden}.kanban-card:hover{transform:translateY(-1px);box-shadow:0 8px 16px #0f172a1f}.kanban-card.dragging{background:#e0f2fe;border-color:#bae6fd;box-shadow:0 6px 12px #0f172a1f}.kanban-card-header{display:flex;align-items:center;justify-content:space-between;gap:6px;flex-wrap:nowrap}.kanban-card h4{margin:0;font-size:.93rem;font-weight:700;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.kanban-move{display:flex;gap:6px;margin:4px 0 2px;flex-wrap:wrap}.move-btn{border:1px solid #e2e8f0;background:#f8fafc;border-radius:10px;padding:6px 8px;cursor:pointer;transition:all .1s ease}.move-btn:hover{background:#e0f2fe;border-color:#0ea5e9}.kanban-card-footer{display:flex;justify-content:space-between;align-items:center;margin-top:4px;color:#64748b;font-size:.9rem}.kanban-card .pill{background:#f1f5f9;color:#0f172a;border:1px solid #e2e8f0}.feed-list{display:flex;flex-direction:column;gap:16px;margin-top:8px}.auth-page{min-height:100vh;display:grid;place-items:center;padding:20px;background:linear-gradient(160deg,#e0f2fe,#f8fafc,#fff)}.auth-card{width:min(460px,100%);padding:34px 32px;border-radius:18px;background:#fff;border:1px solid #e2e8f0;box-shadow:0 24px 40px #0f172a26}.auth-header{display:flex;gap:12px;align-items:center;justify-content:center;margin-bottom:20px}.auth-header.logo-only{justify-content:center}.auth-logo{width:150px;height:auto}.form{display:flex;flex-direction:column;gap:16px;width:100%}label span{display:block;margin-bottom:6px;color:#475569;font-weight:600}.auth-card label{width:100%}.auth-card input,.auth-card select,.auth-card textarea{width:100%;height:48px;padding:12px 14px;border-radius:14px;border:1px solid #d9e2ef;background:#f8fafc;font-size:1rem;font-weight:600;color:#0f172a;box-shadow:inset 0 1px 2px #0f172a0d}.auth-card input:focus,.auth-card select:focus,.auth-card textarea:focus{border-color:#0ea5e9;box-shadow:0 0 0 4px #0ea5e92e;background:#fff}.auth-card input::placeholder{color:#94a3b8;font-weight:500}textarea{resize:vertical}.error-text{color:#ef4444;font-weight:600}.center{text-align:center}.table-card{padding:0;overflow:hidden}.table-row{display:grid;grid-template-columns:.5fr 1.4fr 2fr .8fr .8fr;padding:12px 16px;border-bottom:1px solid #e2e8f0;gap:10px;align-items:center}.table-row.head{background:#f8fafc;font-weight:700}.table-row:last-child{border-bottom:none}.actions{display:flex;gap:10px;margin-top:10px;flex-wrap:wrap}.post-body{margin-top:12px;color:#0f172a}.loading-screen{display:grid;place-items:center;min-height:40vh;gap:10px}.spinner{width:38px;height:38px;border-radius:50%;border:4px solid #e2e8f0;border-top-color:#0ea5e9;animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}@media(max-width:840px){.nav-links{display:none}.app-header{flex-wrap:wrap;gap:12px}.header-actions{width:100%;justify-content:flex-end}.table-row{grid-template-columns:repeat(2,1fr)}}@media(max-width:640px){.search-box input{min-width:100%}.page-content{width:100%;padding:12px}.kanban-grid{min-width:auto;grid-template-columns:repeat(auto-fit,minmax(220px,1fr))}.app-header{position:sticky}}.upload-row{display:flex;gap:8px;align-items:center}.post-form-card{padding:24px;border-radius:16px;box-shadow:0 18px 30px #0f172a1f;border:1px solid #e2e8f0;background:#fff;width:100%}.post-form-card input,.post-form-card textarea,.post-form-card select{background:#f8fafc;border:1px solid #e2e8f0;border-radius:12px;width:100%}.post-form-card textarea{min-height:180px}.post-form-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(320px,1fr));gap:16px}.editor-toolbar{display:flex;gap:8px;margin:6px 0 10px;flex-wrap:wrap}.post-builder{display:grid;grid-template-columns:minmax(0,4fr) minmax(340px,2.5fr);gap:24px;align-items:start}.post-preview{background:#0ea5e90a;border:1px solid #e2e8f0;border-radius:16px;box-shadow:0 14px 28px #0f172a14;padding:18px;display:flex;flex-direction:column;gap:12px}.preview-header{display:flex;align-items:center;justify-content:space-between}.preview-body{border:1px dashed #cbd5e1;border-radius:12px;padding:12px;min-height:180px;background:#fff}.preview-footer ul{margin:6px 0 0;padding-left:16px;color:#475569;line-height:1.4}.chip-btn{border:1px solid #e2e8f0;background:#f8fafc;border-radius:999px;padding:6px 10px;font-weight:600;cursor:pointer;transition:all .15s ease}.chip-btn:hover{background:#e0f2fe;border-color:#bae6fd}.filter-group .inline-label{min-width:180px}.filter-group .search-box{flex:1 1 260px}.filter-group{align-items:flex-end}.feed-list{margin-top:18px}.podium-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:12px}.podium-card{border-radius:16px;padding:16px;border:1px solid #e2e8f0;background:#fff;box-shadow:0 16px 32px #0f172a1f}.podium-card .podium-name{font-weight:700;font-size:1.05rem;margin:6px 0}.podium-card .podium-score{display:flex;flex-direction:column;gap:2px}.podium-card .podium-rank{font-weight:800;letter-spacing:.04em}.podium-card.pos-1{background:linear-gradient(135deg,#fff7e6,#fff);border-color:#fbbf24}.podium-card.pos-2{background:linear-gradient(135deg,#f8fafc,#fff);border-color:#cbd5e1}.podium-card.pos-3{background:linear-gradient(135deg,#fff4ed,#fff);border-color:#f59e0b}.podium-empty{grid-column:1 / -1;padding:16px;border:1px dashed #cbd5e1;border-radius:12px;text-align:center}@media(max-width:960px){.post-builder{grid-template-columns:1fr}}.actions.end{justify-content:flex-end}
