.page-shell{min-height:100vh;background:radial-gradient(120% 120% at 50% 0%,#6366f147,#0f172af0 55%,#020617);color:#0f172a;padding:0 2.5rem 3rem}body,.page-shell{font-family:Inter,system-ui,-apple-system,Segoe UI,Roboto,Helvetica Neue,Arial}:root{--brand-blue: #0b5fff;--brand-blue-600: #0849d9;--brand-blue-300: rgba(11, 95, 255, .12);--brand-blue-100: rgba(11, 95, 255, .06);--muted: #64748b;--danger: #ef4444}h1,h2,h3,h4,h5,h6,.header-left h1{font-family:Montserrat,system-ui,-apple-system,Segoe UI,Roboto,Helvetica Neue,Arial}.hero{display:flex;align-items:center;justify-content:space-between;gap:2rem;padding:1.5rem 0 1.25rem;color:#f8fafc}.app-header{position:sticky;top:0;z-index:40;margin-bottom:0;display:block;pointer-events:auto;background:#020617a6;border-bottom:1px solid rgba(255,255,255,.02)}.app-header .header-inner{width:100%;max-width:1400px;margin:0 auto;padding:6px 12px;display:flex;align-items:center;justify-content:flex-start;gap:12px}.header-left{display:flex;align-items:center;gap:8px}.header-left .brand-text{display:flex;align-items:center}.header-actions{margin-left:auto;display:flex;align-items:center;gap:8px}.tb-icon{-webkit-appearance:none;-moz-appearance:none;appearance:none;border:none;background:#ffffff05;color:var(--brand-blue-600);padding:6px;border-radius:8px;cursor:pointer;display:inline-flex;align-items:center;justify-content:center}.tb-icon:hover{background:#ffffff0a;transform:translateY(-1px)}.tb-logout{color:var(--danger);background:#ef44440f}.topbar-accent,.brand-accent{width:8px;height:8px;border-radius:2px;background:linear-gradient(135deg,var(--brand-blue),var(--brand-blue-600));box-shadow:none}.brand-title{font-size:1.05rem;margin:0;color:var(--brand-blue-600);font-weight:700}.tb-refresh{padding:8px 10px;width:44px;height:44px;border-radius:10px}.user-label{margin-left:8px;padding:4px 8px;border-radius:999px;background:#ffffff05;color:#ffffffe6;font-weight:600;font-size:.9rem}.user-label[title]{cursor:default}.app-header:before,.app-header:after{content:none!important}.brand h1{margin:0;font-size:1.25rem;color:var(--brand-blue-600);line-height:1}.brand-title{color:var(--brand-blue-600)!important;font-family:Montserrat,system-ui,-apple-system,Segoe UI,Roboto,Helvetica Neue,Arial;font-weight:700}.brand-title{font-family:Poppins,Montserrat,system-ui,-apple-system,Segoe UI,Roboto,Helvetica Neue,Arial;letter-spacing:-.01em;font-weight:700}.visually-hidden{position:absolute!important;overflow:hidden!important;clip:rect(1px,1px,1px,1px)!important;height:1px!important;width:1px!important;white-space:nowrap!important}.icon-only{padding:.32rem;width:36px;height:36px;border-radius:8px;display:inline-flex;align-items:center;justify-content:center;gap:0;border:1px solid rgba(255,255,255,.03);background:transparent}.brand-title{font-size:1.05rem}.app-header .header-inner{padding:.28rem .5rem;border-radius:8px;box-shadow:none;border:1px solid rgba(255,255,255,.02)}.app-header{margin-bottom:.6rem}.brand .subtitle{display:none}.brand-accent{width:8px;height:8px;background:linear-gradient(135deg,var(--brand-blue),var(--brand-blue-600));border-radius:2px;margin-right:8px;box-shadow:0 6px 14px #0b5fff1a}.brand-actions{display:inline-flex;align-items:center;gap:8px;margin-left:8px}.brand-title{margin:0}@media (max-width: 880px){.app-header{top:0}.app-header .header-inner{padding:6px 10px;border-radius:6px}.brand .subtitle{display:none}.brand-title{font-size:1.05rem}.header-content,.header-right{gap:.5rem}.user-email{display:none}.user-name{font-size:.9rem}.refresh-label{display:none}.refresh-btn{padding:.28rem;width:36px;height:36px;justify-content:center}.logout-btn{padding:.28rem}}.mobile-menu-wrapper{position:relative}.mobile-menu-btn{display:none;width:40px;height:40px;border-radius:10px;border:1px solid rgba(11,95,255,.08);background:transparent;align-items:center;justify-content:center}.mobile-menu-btn .hamburger{display:block;width:18px;height:2px;background:var(--brand-blue-600);position:relative}.mobile-menu-btn .hamburger:before,.mobile-menu-btn .hamburger:after{content:"";position:absolute;left:0;width:18px;height:2px;background:var(--brand-blue-600)}.mobile-menu-btn .hamburger:before{top:-6px}.mobile-menu-btn .hamburger:after{top:6px}@media (max-width: 880px){.mobile-menu-btn{display:inline-flex}}.mobile-menu{position:absolute;right:0;top:48px;min-width:160px;background:#fffffffa;border-radius:12px;box-shadow:0 18px 40px #0206173d;border:1px solid rgba(11,95,255,.06);padding:8px;display:flex;flex-direction:column;gap:6px;z-index:120}.mobile-action{padding:.5rem .68rem;border-radius:10px;border:none;background:transparent;text-align:left;cursor:pointer;color:var(--brand-blue-600)}.mobile-action.danger{color:var(--danger)}@media (max-width: 520px){.app-header .header-inner{padding:.5rem;border-radius:10px}.brand-title{font-size:1rem}.user-name{display:none}}@media (max-width: 880px){.page-shell{padding-top:1.25rem}}.header-right{display:flex;align-items:center;gap:.75rem}.refresh-btn{display:inline-flex;align-items:center;gap:.6rem;padding:.45rem .9rem;border-radius:12px;font-weight:600;cursor:pointer;background:linear-gradient(90deg,#0b5fff0f,#0b5fff05);border:1px solid rgba(11,95,255,.12);color:var(--brand-blue-600);transition:transform .16s cubic-bezier(.2,.9,.2,1),box-shadow .16s ease,background .16s ease;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.refresh-btn svg{display:block;color:var(--brand-blue-600)}.refresh-btn:hover{transform:translateY(-4px) scale(1.01);background:linear-gradient(90deg,#0b5fff1a,#0b5fff08);box-shadow:0 14px 40px #0b5fff14}.refresh-label{display:none}.user-info{display:flex;flex-direction:row;align-items:center;gap:.5rem;margin-right:.25rem}.user-name{font-weight:600;color:#0f172a;font-size:.92rem}.user-email{font-size:.78rem;color:var(--muted)}.logout-btn{display:inline-flex;align-items:center;gap:.5rem;padding:.45rem .75rem;border-radius:10px;background:transparent;color:var(--brand-blue-600);border:1px solid rgba(11,95,255,.1);cursor:pointer;font-weight:700;transition:transform .16s ease,box-shadow .16s ease,background .16s ease}.logout-btn svg{color:var(--brand-blue-600)}.logout-btn:hover{background:#0b5fff0f;transform:translateY(-3px);box-shadow:0 10px 30px #0b5fff0f}.logout-btn.danger{color:var(--danger);border:1px solid rgba(239,68,68,.12)}.logout-btn.danger svg{color:var(--danger)}.logout-btn.danger:hover{background:#ef44440f;box-shadow:0 8px 18px #ef44440f}.brand-logo{display:inline-flex;align-items:center;justify-content:center;width:36px;height:28px;border-radius:6px;overflow:hidden}.hero__text h1{margin:0 0 .75rem;font-size:3rem;font-weight:700;letter-spacing:-.02em}.hero__text p{margin:0 0 1.5rem;max-width:560px;font-size:1.1rem;color:#f8fafcc7}.hero__actions{display:flex;flex-wrap:wrap;gap:.75rem}.hero__stats{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:1rem}.stat-card{background:#0f172a8c;border-radius:18px;padding:1rem 1.25rem;color:#e2e8f0;box-shadow:0 20px 40px #0f172a47;-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px)}.stat-card span{font-size:.85rem;text-transform:uppercase;letter-spacing:.08em;color:#94a3b8b8}.stat-card strong{display:block;font-size:1.8rem;margin-top:.3rem}.main-layout{display:grid;grid-template-columns:minmax(0,1fr) 360px;align-items:start;gap:2rem}.board-panel{background:#f8fafceb;border-radius:26px;padding:2rem;box-shadow:0 36px 80px #0f172a38;-webkit-backdrop-filter:blur(26px);backdrop-filter:blur(26px);position:relative}.board-panel:after{content:"";position:absolute;top:20px;right:20px;bottom:20px;left:20px;border-radius:20px;pointer-events:none;border:1px solid rgba(148,163,184,.15)}.board-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem}.board-header h2{margin:0;font-size:1.5rem;color:#0f172a}.board-container{position:relative;z-index:1}.columns-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:1.5rem}@media (max-width: 720px){.board-panel{padding:1rem}.columns-grid{display:flex;flex-direction:row;gap:1rem;overflow-x:auto;padding-bottom:.5rem;-webkit-overflow-scrolling:touch}.columns-grid::-webkit-scrollbar{height:10px}.columns-grid::-webkit-scrollbar-thumb{background:#0b5fff14;border-radius:999px}.column{min-width:260px;flex:0 0 260px;max-width:90%;min-height:360px}.column-content{min-height:140px;max-height:60vh;overflow-y:auto}.task-card{padding:.9rem}.task-card__body h3{font-size:1rem}}.column{background:#fff;border-radius:20px;padding:1.25rem;display:flex;flex-direction:column;min-height:520px;border:1px solid rgba(148,163,184,.15);box-shadow:0 16px 30px #0f172a14}.column.is-over{box-shadow:0 24px 40px #0b5fff2e;border-color:#0b5fff73}.column h2{margin:0 0 .6rem;font-size:1rem;letter-spacing:.06em;color:var(--brand-blue-600);font-weight:600;text-transform:none}.column-content{display:flex;flex-direction:column;flex:1;min-height:200px;padding:8px;border-radius:12px;transition:background-color .2s ease}.column.is-over .column-content{background-color:#6366f10d}.empty-state{display:flex;align-items:center;justify-content:center;flex:1;min-height:120px;color:#94a3b8;font-size:.9rem;border:2px dashed rgba(148,163,184,.3);border-radius:12px;background:#f8fafc80;margin:4px 0}.column.is-over .empty-state{border-color:#6366f166;background-color:#6366f114;color:#6366f1}.column-content::-webkit-scrollbar{width:8px}.column-content::-webkit-scrollbar-thumb{background:#0b5fff73;border-radius:999px}.task-card-wrapper{border-radius:18px;transition:transform .16s ease,box-shadow .16s ease,opacity .2s ease;outline:none;margin-bottom:.75rem;cursor:grab}.task-card-wrapper:active{cursor:grabbing}.task-card-wrapper.is-dragging{opacity:.4;transform:scale(.95)}.column-content .task-card-wrapper:last-of-type{margin-bottom:0}.task-card-wrapper:focus-visible{outline:2px solid rgba(99,102,241,.6)}.task-card{background:#fff;border-radius:18px;padding:1.2rem;display:flex;flex-direction:column;gap:1rem;box-shadow:inset 0 0 0 1px #0f172a0a}.task-card.is-dragging{box-shadow:0 8px 16px #4f46e533;opacity:1}.task-card-wrapper.drag-overlay{cursor:grabbing;transform:none!important;transition:none!important;margin:0;opacity:1}.task-card__body h3{margin:0;font-size:1.05rem;color:#0f172a}.task-card__body p{margin:0;color:#475569;line-height:1.5}.task-card__meta{display:flex;gap:.6rem}.task-card__meta button{flex:1;padding:.6rem .8rem;border-radius:14px;border:none;font-weight:600;background:var(--brand-blue-100);color:var(--brand-blue-600);cursor:pointer;transition:transform .12s ease,background .12s ease}.task-card__meta button:hover{transform:translateY(-2px);background:#0b5fff2e}.task-card__meta button.danger{background:#ef444424;color:#b91c1c}.task-card__meta button.danger:hover{background:#ef44443d}.form-panel{display:flex;flex-direction:column;gap:1.5rem}.panel-card{background:#f8fafcf2;border-radius:22px;padding:1.75rem;box-shadow:0 28px 60px #0f172a2e;border:1px solid rgba(148,163,184,.18);-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px)}.panel-card h3{margin:0 0 1rem;font-size:1.1rem;color:#0f172a}.task-form{display:flex;flex-direction:column;gap:.9rem}.task-form label{display:flex;flex-direction:column;gap:.4rem;font-size:.9rem;color:#475569;text-transform:uppercase;letter-spacing:.08em}.task-form input,.task-form textarea,.task-form select{border-radius:14px;border:1px solid rgba(148,163,184,.4);padding:.75rem .9rem;font:inherit;background:#ffffffe6;color:#0f172a}.task-form textarea{min-height:140px;resize:vertical}.task-form__actions{display:flex;gap:.8rem;justify-content:flex-end}.btn{border:none;border-radius:14px;font-weight:600;padding:.7rem 1.1rem;cursor:pointer;transition:transform .12s ease,box-shadow .12s ease}.btn.primary{background:linear-gradient(135deg,var(--brand-blue-600),var(--brand-blue));color:#f8fafc;box-shadow:0 18px 30px #0b5fff47}.btn.primary:hover{transform:translateY(-2px)}.btn.ghost{background:var(--brand-blue-100);color:var(--brand-blue-600);border:1px solid rgba(11,95,255,.18);padding:.5rem .9rem;border-radius:10px;font-size:.95rem}.btn.ghost:hover{transform:translateY(-2px);background:#4f46e524}.board-header{display:flex;align-items:center;justify-content:space-between;gap:1rem}.board-header .ai-button{background:var(--brand-blue-100);border:1px solid rgba(11,95,255,.06);color:var(--brand-blue-600);padding:.45rem .8rem;border-radius:10px;font-weight:600;font-size:.92rem;display:inline-flex;align-items:center;gap:.5rem}.board-header .ai-button:hover{transform:translateY(-1px);box-shadow:0 6px 14px #6366f10f}.board-header .ai-button svg{width:16px;height:16px;display:block;fill:currentColor}.ai-float-btn{position:absolute;right:1.25rem;top:1.25rem;width:36px;height:36px;border-radius:10px;display:inline-flex;align-items:center;justify-content:center;background:var(--brand-blue-100);border:1px solid rgba(11,95,255,.06);color:var(--brand-blue-600);cursor:pointer;transition:transform .12s ease,box-shadow .12s ease}.ai-float-btn svg{width:16px;height:16px;fill:currentColor}.ai-float-btn:hover{transform:translateY(-2px);box-shadow:0 6px 16px #0b5fff14}.board-panel{position:relative}.banner{margin:0 auto 1.5rem;max-width:960px;padding:.9rem 1.2rem;border-radius:14px;font-size:.95rem}.banner.error{background:#ef444429;color:#fee2e2;border:1px solid rgba(239,68,68,.36)}.empty-state{padding:1.4rem;text-align:center;font-size:.95rem;color:#64748b;border:1px dashed rgba(148,163,184,.5);border-radius:16px}.loading-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0f172a7a;display:flex;align-items:center;justify-content:center;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);z-index:40}.spinner{width:28px;height:28px;border-radius:50%;border:3px solid rgba(11,95,255,.22);border-top-color:var(--brand-blue);animation:spin .9s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.assistant-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#020617b8;-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px);display:flex;align-items:flex-start;justify-content:center;padding:4rem 1.5rem;z-index:60}.assistant-modal{background:#f8fafcfa;border-radius:28px;width:min(1080px,100%);max-height:calc(100vh - 8rem);display:flex;flex-direction:column;box-shadow:0 40px 120px #0f172a73;border:1px solid rgba(148,163,184,.25);overflow:hidden}.assistant-modal__header{display:flex;justify-content:space-between;align-items:center;padding:2rem 2.25rem 1.5rem;gap:1.5rem}.assistant-modal__header h2{margin:0 0 .4rem;font-size:1.5rem;color:#0f172a}.assistant-modal__header p{margin:0;color:#475569}.assistant-modal__body{display:grid;grid-template-columns:380px minmax(0,1fr);gap:2rem;padding:0 2.25rem 2.25rem;overflow:hidden;flex:1;align-items:start}.assistant-modal__task{background:#fff;border-radius:20px;padding:1.5rem;border:1px solid rgba(148,163,184,.2);box-shadow:0 18px 40px #0f172a1f;overflow-y:auto}.assistant-modal__chat{display:flex;flex-direction:column;background:#fff;border-radius:24px;border:1px solid rgba(148,163,184,.2);box-shadow:0 18px 40px #0f172a1f;overflow:hidden}.assistant-placeholder{padding:1.5rem;text-align:center;color:#64748b;font-size:.95rem}.chat-log{flex:1;overflow-y:auto;padding:1.75rem 1.75rem 1rem;display:flex;flex-direction:column;gap:1.25rem}.chat-message{display:flex}.chat-message--user{justify-content:flex-end}.chat-message__bubble{max-width:520px;padding:1.1rem 1.25rem;border-radius:18px;background:var(--brand-blue-100);color:#1e293b;box-shadow:inset 0 0 0 1px #0b5fff24}.chat-message--assistant .chat-message__bubble{background:#0f172a0d;box-shadow:inset 0 0 0 1px #94a3b840}.chat-message__role{display:block;font-size:.75rem;text-transform:uppercase;letter-spacing:.08em;color:#47556999;margin-bottom:.35rem}.chat-message__bubble p{margin:0;white-space:pre-wrap}.chat-message__tasks{margin-top:1rem;display:flex;flex-direction:column;gap:.75rem}.chat-task{display:flex;justify-content:space-between;align-items:flex-start;gap:.75rem;padding:.85rem 1rem;border-radius:14px;border:1px solid rgba(11,95,255,.18);background:#0b5fff0f;color:var(--brand-blue-600);cursor:pointer;transition:transform .12s ease,box-shadow .12s ease}.chat-task:hover{transform:translateY(-2px);box-shadow:0 10px 24px #0b5fff29}.chat-task strong{display:block;margin-bottom:.2rem}.chat-task span{display:block;font-size:.85rem;color:#0b5fffa6}.chat-task__status{font-size:.75rem;padding:.25rem .55rem;border-radius:999px;text-transform:uppercase;letter-spacing:.1em}.chat-task__status--todo{background:#0b5fff26;color:var(--brand-blue-600)}.chat-task__status--doing{background:#0b5fff33;color:var(--brand-blue-600)}.chat-task__status--done{background:#22c55e33;color:#166534}.chat-input{border-top:1px solid rgba(148,163,184,.25);padding:1.25rem 1.5rem 1.5rem;display:flex;flex-direction:column;gap:.75rem}.chat-input textarea{width:100%;border-radius:16px;border:1px solid rgba(148,163,184,.35);padding:.9rem 1rem;resize:none;min-height:100px;background:#f8fafce6;color:#0f172a}.chat-input__actions{display:flex;justify-content:flex-end}.edit-modal{background:#f8fafcfa;border-radius:28px;width:min(540px,100%);max-height:calc(100vh - 8rem);display:flex;flex-direction:column;box-shadow:0 40px 120px #0f172a73;border:1px solid rgba(148,163,184,.25);overflow:hidden}.edit-modal__header{display:flex;justify-content:space-between;align-items:center;padding:2rem 2.25rem 1.5rem;border-bottom:1px solid rgba(148,163,184,.15)}.edit-modal__header h2{margin:0;font-size:1.75rem;color:#0f172a}.edit-modal__form{padding:2rem 2.25rem;display:flex;flex-direction:column;gap:1.5rem}.form-group{display:flex;flex-direction:column;gap:.5rem}.form-group label{font-size:.9rem;font-weight:600;color:#374151;text-transform:uppercase;letter-spacing:.05em}.form-group input,.form-group textarea,.form-group select{padding:.875rem 1rem;border:1px solid rgba(148,163,184,.3);border-radius:12px;font-size:1rem;background:#fff;transition:border-color .16s ease,box-shadow .16s ease}.form-group input:focus,.form-group textarea:focus,.form-group select:focus{outline:none;border-color:#6366f1;box-shadow:0 0 0 3px #6366f11a}.form-group textarea{resize:vertical;font-family:inherit}.edit-modal__actions{display:flex;gap:.75rem;justify-content:flex-end;padding-top:1rem;border-top:1px solid rgba(148,163,184,.15);margin-top:.5rem}@media (max-width: 900px){.assistant-modal__body{grid-template-columns:1fr}.assistant-modal__task{order:2}.assistant-modal__chat{order:1}}@media (max-width: 720px){.assistant-backdrop{padding:1rem;align-items:center;justify-content:center}.assistant-modal{width:96vw;max-height:96vh;border-radius:14px;overflow:hidden;display:flex;flex-direction:column}.assistant-modal__header{padding:.85rem 1rem;gap:.75rem}.assistant-modal__header h2{font-size:1.25rem}.assistant-modal__body{grid-template-columns:1fr;gap:.75rem;padding:.5rem .75rem .75rem;align-items:stretch}.assistant-modal__task,.assistant-modal__chat{padding:.85rem;border-radius:12px;max-height:46vh;overflow-y:auto}.assistant-placeholder{font-size:.95rem;padding:.75rem}.chat-log{padding:.85rem}.chat-input{padding:.75rem}.chat-input textarea{min-height:80px;max-height:30vh}.chat-input__actions{padding-top:.5rem}.assistant-modal__header .btn{padding:.5rem .75rem;font-size:.95rem}}.ai-panel{display:flex;flex-direction:column;gap:1rem}.ai-panel h3{margin:0;font-size:1.1rem;color:#1e293b}.help-text{margin:0;color:#64748b;font-size:.85rem}.ai-panel__actions{display:flex;gap:.6rem}.ai-panel__actions button{flex:1;padding:.55rem .8rem;border-radius:12px;border:1px solid rgba(99,102,241,.25);background:#6366f11f;color:#4338ca;cursor:pointer;font-weight:600;transition:background .12s ease}.ai-panel__actions button:disabled{opacity:.6;cursor:wait}.ai-panel__actions button:hover:not(:disabled){background:#6366f133}.ai-panel__result{border-radius:16px;border:1px solid rgba(148,163,184,.35);background:#f8fafce6;padding:1rem;white-space:pre-wrap;color:#1f2937;min-height:120px}@media (max-width: 1200px){.hero{flex-direction:column;text-align:center;padding:1rem 0 .9rem}.hero__text p{margin-left:auto;margin-right:auto}.hero__stats{width:100%}.main-layout{grid-template-columns:1fr}.board-panel{padding:1.5rem}.columns-grid{grid-template-columns:repeat(auto-fit,minmax(260px,1fr))}}@media (max-width: 768px){.page-shell{padding:0 1.25rem 2.5rem}.hero__text h1{font-size:2.4rem}.hero__stats{grid-template-columns:repeat(auto-fit,minmax(140px,1fr))}}.app-header{background:#0f172a99;border-bottom:1px solid rgba(226,232,240,.03);padding:.35rem 0;margin-bottom:.5rem;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.header-content{display:flex;align-items:center;justify-content:space-between;gap:1rem}.header-left{display:flex;align-items:center;gap:.75rem}.header-left h1{margin:0;font-size:1.5rem;font-weight:700;color:#10b981}.subtitle{color:#f8fafc99;font-size:.9rem}.header-right{display:flex;align-items:center;gap:.5rem}.user-info{display:flex;flex-direction:row;align-items:center;gap:.5rem}.user-name{color:#f8fafc;font-weight:600;font-size:.9rem}.user-email{color:#f8fafc99;font-size:.78rem}.logout-btn{display:inline-flex;align-items:center;gap:.4rem;padding:.28rem .44rem;border-radius:8px;background:#ef44440f;color:#f97373;border:1px solid rgba(239,68,68,.12);font-size:.9rem;cursor:pointer;transition:all .14s ease}.logout-btn:hover{background:#ef44441f}.logout-btn svg{width:16px;height:16px}.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#10b981,#3b82f6);padding:2rem}.loading-container{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100vh;color:#f8fafc;gap:1rem}.loading-spinner{width:40px;height:40px;border:3px solid rgba(248,250,252,.2);border-top:3px solid #10b981;border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@media (max-width: 768px){.header-content{flex-direction:column;gap:1rem}.user-info{align-items:center}.header-right{flex-direction:column;gap:.75rem}.login-page{padding:1rem}}.login-container{background:#fffffff2;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-radius:12px;box-shadow:0 4px 20px #00000014;padding:2rem;width:100%;max-width:400px;border:1px solid rgba(255,255,255,.2);margin:2rem auto}.login-header{text-align:center;margin-bottom:2rem}.login-header h1{color:var(--primary, #10b981);font-size:2rem;font-weight:700;margin-bottom:.5rem}.login-header p{color:var(--text-muted, #64748b);font-size:.9rem}.login-form{margin-bottom:1rem}.form-group{margin-bottom:1.5rem}.form-group label{display:block;margin-bottom:.5rem;font-weight:500;color:var(--text-primary, #1f2937)}.form-input{width:100%;padding:.75rem;border:1px solid var(--border-color, #e5e7eb);border-radius:8px;font-size:1rem;transition:all .2s ease;background:var(--bg, #ffffff)}.form-input:focus{outline:none;border-color:var(--primary, #10b981);box-shadow:0 0 0 3px #10b9811a}.form-input:disabled{opacity:.6;cursor:not-allowed}.form-row{display:flex;gap:1rem}.form-row .form-group{flex:1}.btn{width:100%;padding:.75rem;border:none;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s ease;margin-bottom:1rem}.btn-primary{background:var(--primary, #10b981);color:#fff}.btn-primary:hover:not(:disabled){background:var(--primary-alt, #059669);transform:translateY(-1px)}.btn:disabled{opacity:.6;cursor:not-allowed;transform:none!important}.alert{padding:.75rem;border-radius:8px;margin-bottom:1rem;font-size:.9rem}.alert-error{background:#fef2f2;border:1px solid #fecaca;color:#dc2626}.alert-success{background:#f0fdf4;border:1px solid #bbf7d0;color:#16a34a}.divider{margin:1.5rem 0;text-align:center;position:relative}.divider:before{content:"";position:absolute;top:50%;left:0;right:0;height:1px;background:var(--border-color, #e5e7eb)}.divider span{background:var(--bg, #ffffff);padding:0 1rem;color:var(--text-muted, #64748b);font-size:.9rem}.toggle-mode{text-align:center}.google-signin-container{display:flex;justify-content:center;margin:1rem 0}.google-signin-button{width:100%;max-width:400px}.google-signin-container .g_id_signin,.google-signin-container iframe{width:100%!important}.link-button{background:none;border:none;color:var(--primary, #10b981);text-decoration:none;font-weight:500;cursor:pointer;padding:0;font-size:inherit}.link-button:hover:not(:disabled){text-decoration:underline}.link-button:disabled{opacity:.6;cursor:not-allowed}@media (max-width: 480px){.login-container{margin:1rem;padding:1.5rem}.form-row{flex-direction:column;gap:0}}:root{font-family:Inter,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;line-height:1.5;font-weight:400;color:#0f172a;background-color:#020617;color-scheme:light}*{box-sizing:border-box}body{margin:0;min-height:100vh;background:#020617}a{color:inherit;text-decoration:none}button,textarea{font:inherit}
