:root{--color-primary-50: #f0f0ff;--color-primary-100: #e0e1ff;--color-primary-200: #c7c8ff;--color-primary-400: #818cf8;--color-primary-500: #667eea;--color-primary-600: #5a6fd6;--color-primary-700: #764ba2;--color-primary-800: #5b3a7d;--color-gradient: linear-gradient(135deg, #667eea 0%, #764ba2 100%);--color-gray-50: #f9fafb;--color-gray-100: #f3f4f6;--color-gray-200: #e5e7eb;--color-gray-300: #d1d5db;--color-gray-400: #9ca3af;--color-gray-500: #6b7280;--color-gray-600: #4b5563;--color-gray-700: #374151;--color-gray-800: #1f2937;--color-gray-900: #111827;--color-success: #22c55e;--color-danger: #ef4444;--color-error: var(--color-danger);--color-warning: #f59e0b;--font-family: "Inter", system-ui, -apple-system, "Segoe UI", sans-serif;--font-mono: "JetBrains Mono", "Fira Code", ui-monospace, monospace;--text-xs: .75rem;--text-sm: .875rem;--text-base: 1rem;--text-lg: 1.125rem;--text-xl: 1.25rem;--text-2xl: 1.5rem;--space-1: .25rem;--space-2: .5rem;--space-3: .75rem;--space-4: 1rem;--space-5: 1.25rem;--space-6: 1.5rem;--space-8: 2rem;--space-10: 2.5rem;--space-12: 3rem;--radius-sm: 6px;--radius-md: 8px;--radius-lg: 12px;--radius-full: 9999px;--shadow-sm: 0 1px 2px rgba(0, 0, 0, .05);--shadow-md: 0 4px 6px -1px rgba(0, 0, 0, .1);--shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, .1);--shadow-xl: 0 20px 25px -5px rgba(0, 0, 0, .1);--sidebar-width: 320px;--sidebar-width-mobile: min(300px, 85vw);--topbar-height: 56px;--transition-fast: .15s ease;--transition-base: .2s ease;--transition-slow: .3s ease}*,*:before,*:after{box-sizing:border-box}body{margin:0;font-family:var(--font-family);line-height:1.5;color:var(--color-gray-900);background:#fff;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}#root{min-height:100vh}a{color:var(--color-primary-500);text-decoration:none}button{font-family:inherit;cursor:pointer}input,textarea{font-family:inherit}.login-container{display:flex;justify-content:center;align-items:center;min-height:100vh;background:var(--color-gradient);padding:var(--space-5)}iframe[src*="accounts.google.com"]{display:none!important}.login-card{background:#fff;border-radius:var(--radius-lg);box-shadow:0 20px 60px #0000004d;padding:var(--space-8);width:100%;max-width:400px;animation:slideUp .6s ease-out}@keyframes slideUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}.login-title{font-size:2.5rem;font-weight:700;margin:0 0 var(--space-2) 0;background:var(--color-gradient);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;text-align:center}.login-subtitle{font-size:var(--text-sm);color:var(--color-gray-500);text-align:center;margin:0 0 var(--space-6) 0;font-weight:500}.login-error{background-color:#fee;border:1px solid #fcc;border-radius:var(--radius-md);padding:var(--space-3) var(--space-4);margin-bottom:var(--space-5);display:flex;align-items:flex-start;gap:var(--space-2);animation:shake .5s ease-in-out}.error-icon{font-size:var(--text-lg);flex-shrink:0}.login-error p{margin:0;color:var(--color-error);font-size:var(--text-sm)}@keyframes shake{0%,to{transform:translate(0)}25%{transform:translate(-10px)}75%{transform:translate(10px)}}.login-button-wrapper{display:flex;justify-content:center;margin:var(--space-6) 0;min-height:45px}.google-button-container{display:flex;justify-content:center;width:100%}.microsoft-button-container{display:flex!important;justify-content:center;width:100%;margin-top:var(--space-3);min-height:50px}.microsoft-signin-button{display:flex;align-items:center;justify-content:center;gap:var(--space-2);padding:var(--space-2) var(--space-5);background:#fff;border:1px solid var(--color-gray-200);border-radius:4px;cursor:pointer;font-size:16px;font-weight:500;color:var(--color-gray-900);transition:all var(--transition-fast);width:100%;max-width:380px}.microsoft-signin-button:hover{background:var(--color-gray-50);border-color:var(--color-gray-400);box-shadow:var(--shadow-sm)}.microsoft-signin-button:active{background:var(--color-gray-100);transform:scale(.98)}.microsoft-logo{width:20px;height:20px;flex-shrink:0}.google-signin-button-fallback{display:flex;align-items:center;justify-content:center;gap:var(--space-2);padding:var(--space-2) var(--space-5);background:#fff;border:1px solid var(--color-gray-200);border-radius:4px;cursor:not-allowed;font-size:var(--text-sm);font-weight:500;color:var(--color-gray-400);width:100%;max-width:380px;opacity:.6}.google-button-container.highlight{outline:3px solid #4285f4;border-radius:4px;padding:2px}.microsoft-button-container.highlight{outline:3px solid #0078d4;border-radius:4px;padding:2px}.error-hint{margin:var(--space-2) 0 0 0;color:var(--color-error);font-size:var(--text-xs);font-weight:600}.login-buttons{display:flex;flex-direction:column;gap:0}.login-loading{display:flex;flex-direction:column;align-items:center;gap:var(--space-4)}.spinner{width:40px;height:40px;border:3px solid var(--color-gray-100);border-top:3px solid var(--color-primary-500);border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.login-loading p{color:var(--color-primary-500);font-weight:600;margin:0}.login-info{border-top:1px solid var(--color-gray-100);padding-top:var(--space-5);margin-top:var(--space-5)}.login-info p{font-size:var(--text-xs);color:var(--color-gray-400);text-align:center;margin:var(--space-2) 0;line-height:1.4}.login-info p:first-child{margin-top:0}.login-info p:last-child{margin-bottom:0}.oauth-login{width:100%}@media(max-width:480px){.login-card{padding:var(--space-6) var(--space-5);border-radius:var(--radius-lg)}.login-title{font-size:2rem}.login-subtitle{font-size:var(--text-xs);margin-bottom:var(--space-5)}.login-button-wrapper{margin:var(--space-5) 0}}@media(max-width:360px){.login-container{padding:var(--space-3)}.login-card{padding:var(--space-5) var(--space-4)}.login-title{font-size:1.75rem}}.top-bar{display:flex;justify-content:space-between;align-items:center;height:var(--topbar-height);padding:0 var(--space-6);background:#fff;border-bottom:1px solid var(--color-gray-200);z-index:100}.top-bar-left{display:flex;align-items:center;gap:var(--space-3)}.top-bar-hamburger{display:none;align-items:center;justify-content:center;width:36px;height:36px;padding:0;border:none;border-radius:var(--radius-md);background:none;color:var(--color-gray-600);transition:background var(--transition-fast)}.top-bar-hamburger:hover{background:var(--color-gray-100)}.top-bar-logo{font-size:var(--text-xl);font-weight:700;background:var(--color-gradient);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.top-bar-right{display:flex;align-items:center;gap:var(--space-4)}.top-bar-user{display:flex;align-items:center;gap:var(--space-2)}.top-bar-avatar{width:32px;height:32px;border-radius:var(--radius-full);object-fit:cover;flex-shrink:0}.top-bar-avatar--placeholder{display:flex;align-items:center;justify-content:center;background:var(--color-gradient);color:#fff;font-weight:600;font-size:var(--text-sm)}.top-bar-name{font-size:var(--text-sm);font-weight:500;color:var(--color-gray-700)}.top-bar-logout{padding:var(--space-2) var(--space-4);border:1px solid var(--color-gray-200);border-radius:var(--radius-sm);background:#fff;color:var(--color-gray-600);font-size:var(--text-sm);font-weight:500;transition:all var(--transition-fast)}.top-bar-logout:hover:not(:disabled){background:var(--color-gray-50);border-color:var(--color-gray-300);color:var(--color-danger)}.top-bar-logout:disabled{opacity:.5;cursor:not-allowed}@media(max-width:768px){.top-bar{padding:0 var(--space-3)}.top-bar-hamburger{display:flex;width:44px;height:44px}.top-bar-name{display:none}}@media(max-width:400px){.top-bar-logo{font-size:var(--text-lg)}.top-bar-logout{padding:var(--space-1) var(--space-2);font-size:var(--text-xs)}}.sidebar{display:flex;flex-direction:column;height:100%}.sidebar__header{display:flex;justify-content:space-between;align-items:center;padding:var(--space-4) var(--space-4) var(--space-3);border-bottom:1px solid var(--color-gray-100)}.sidebar__title{margin:0;font-size:var(--text-sm);font-weight:600;color:var(--color-gray-500);text-transform:uppercase;letter-spacing:.05em}.sidebar__add-btn{width:36px;height:36px;padding:0;border:1px solid var(--color-gray-200);border-radius:var(--radius-sm);background:#fff;color:var(--color-gray-600);font-size:var(--text-lg);line-height:1;display:flex;align-items:center;justify-content:center;transition:all var(--transition-fast)}.sidebar__add-btn:hover{background:var(--color-primary-50);border-color:var(--color-primary-200);color:var(--color-primary-500)}.sidebar__create{padding:var(--space-3) var(--space-4);border-bottom:1px solid var(--color-gray-100);background:var(--color-gray-50);display:flex;flex-direction:column;gap:var(--space-2)}.sidebar__create input,.sidebar__create textarea{width:100%;padding:var(--space-2) var(--space-3);border:1px solid var(--color-gray-200);border-radius:var(--radius-sm);font-size:var(--text-sm);background:#fff;resize:none}.sidebar__create input:focus,.sidebar__create textarea:focus{outline:none;border-color:var(--color-primary-500);box-shadow:0 0 0 2px var(--color-primary-100)}.sidebar__create-actions{display:flex;gap:var(--space-2);justify-content:flex-end}.sidebar__create-cancel{padding:var(--space-1) var(--space-3);border:none;border-radius:var(--radius-sm);background:none;color:var(--color-gray-500);font-size:var(--text-sm)}.sidebar__create-submit{padding:var(--space-1) var(--space-3);border:none;border-radius:var(--radius-sm);background:var(--color-primary-500);color:#fff;font-size:var(--text-sm);font-weight:500;transition:background var(--transition-fast)}.sidebar__create-submit:hover:not(:disabled){background:var(--color-primary-600)}.sidebar__create-submit:disabled{opacity:.5;cursor:not-allowed}.sidebar__invitations{border-bottom:1px solid var(--color-gray-100)}.sidebar__invitations-toggle{display:flex;align-items:center;gap:var(--space-2);width:100%;padding:var(--space-3) var(--space-4);border:none;background:var(--color-warning);color:#fff;font-size:var(--text-sm);font-weight:500;text-align:left}.sidebar__invitations-toggle:hover{filter:brightness(.95)}.sidebar__invitations-badge{display:inline-flex;align-items:center;justify-content:center;width:20px;height:20px;border-radius:var(--radius-full);background:#fff;color:var(--color-warning);font-size:var(--text-xs);font-weight:700}.sidebar__chevron{margin-left:auto;font-size:var(--text-lg);transition:transform var(--transition-fast)}.sidebar__chevron--open{transform:rotate(90deg)}.sidebar__invitations-list{padding:var(--space-2) var(--space-4) var(--space-3);background:#fef3c7;display:flex;flex-direction:column;gap:var(--space-2)}.sidebar__invitation{background:#fff;border-radius:var(--radius-sm);padding:var(--space-2) var(--space-3)}.sidebar__invitation-info{display:flex;flex-direction:column;margin-bottom:var(--space-2)}.sidebar__invitation-info strong{font-size:var(--text-sm);color:var(--color-gray-900)}.sidebar__invitation-info span{font-size:var(--text-xs);color:var(--color-gray-500)}.sidebar__invitation-actions{display:flex;gap:var(--space-2)}.sidebar__inv-accept,.sidebar__inv-decline{padding:var(--space-2) var(--space-4);border:none;border-radius:var(--radius-sm);font-size:var(--text-sm);font-weight:500}.sidebar__inv-accept{background:var(--color-success);color:#fff}.sidebar__inv-accept:hover{filter:brightness(.9)}.sidebar__inv-decline{background:var(--color-gray-100);color:var(--color-gray-600)}.sidebar__inv-decline:hover{background:var(--color-gray-200)}.sidebar__list{flex:1;overflow-y:auto;padding:var(--space-2) 0}.sidebar__item{display:flex;align-items:center;gap:var(--space-3);width:100%;padding:var(--space-3) var(--space-4);border:none;border-left:3px solid transparent;background:none;text-align:left;transition:all var(--transition-fast)}.sidebar__item:hover{background:var(--color-gray-50)}.sidebar__item--active{background:var(--color-primary-50);border-left-color:var(--color-primary-500)}.sidebar__item-avatar{width:36px;height:36px;border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;color:#fff;font-weight:600;font-size:var(--text-sm);flex-shrink:0}.sidebar__item-info{display:flex;flex-direction:column;min-width:0}.sidebar__item-name{font-size:var(--text-sm);font-weight:500;color:var(--color-gray-900);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sidebar__item-meta{display:flex;align-items:center;gap:var(--space-1);font-size:var(--text-xs);color:var(--color-gray-400)}.sidebar__owner-dot{display:inline-block;width:6px;height:6px;border-radius:var(--radius-full);background:var(--color-primary-500)}.sidebar__empty{display:flex;flex-direction:column;align-items:center;padding:var(--space-8) var(--space-4);text-align:center}.sidebar__empty p{margin:0 0 var(--space-3);color:var(--color-gray-400);font-size:var(--text-sm)}.sidebar__empty-cta{padding:var(--space-2) var(--space-4);border:1px dashed var(--color-primary-200);border-radius:var(--radius-sm);background:none;color:var(--color-primary-500);font-size:var(--text-sm);font-weight:500;transition:all var(--transition-fast)}.sidebar__empty-cta:hover{background:var(--color-primary-50);border-style:solid}@media(max-width:768px){.sidebar__item{padding:var(--space-4) var(--space-4)}}.codes-panel{display:flex;flex-direction:column;gap:var(--space-5)}.codes-panel--loading{padding:var(--space-8);text-align:center;color:var(--color-gray-400)}.codes-panel__timer{background:var(--color-gray-50);border-radius:var(--radius-md);padding:var(--space-3) var(--space-4)}.codes-panel__timer-row{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--space-2)}.codes-panel__timer-label{font-size:var(--text-sm);color:var(--color-gray-500);font-weight:500}.codes-panel__timer-value{font-size:var(--text-lg);font-weight:700;font-variant-numeric:tabular-nums;min-width:40px;text-align:right}.codes-panel__timer-value--green{color:var(--color-success)}.codes-panel__timer-value--amber{color:var(--color-warning)}.codes-panel__timer-value--red{color:var(--color-error)}.codes-panel__progress{height:6px;background:var(--color-gray-200);border-radius:var(--radius-full);overflow:hidden}.codes-panel__progress-bar{height:100%;border-radius:var(--radius-full);transition:width 1s linear}.codes-panel__progress-bar--green{background:var(--color-success)}.codes-panel__progress-bar--amber{background:var(--color-warning)}.codes-panel__progress-bar--red{background:var(--color-error);animation:pulse-bar 1s ease-in-out infinite}@keyframes pulse-bar{0%,to{opacity:1}50%{opacity:.6}}.codes-panel__empty{text-align:center;padding:var(--space-8) var(--space-4);color:var(--color-gray-400)}.codes-panel__empty p{margin:var(--space-1) 0;font-size:var(--text-sm)}.codes-panel__grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(min(280px,100%),1fr));gap:var(--space-4)}.codes-panel__grid--animating .code-card{animation:fade-in .4s ease-out}@keyframes fade-in{0%{opacity:0;transform:translateY(4px)}to{opacity:1;transform:translateY(0)}}.code-card{background:#fff;border:1px solid var(--color-gray-200);border-radius:var(--radius-md);overflow:hidden;transition:border-color var(--transition-fast),box-shadow var(--transition-fast)}.code-card:hover{border-color:var(--color-primary-300);box-shadow:var(--shadow-sm)}.code-card__header{padding:var(--space-3) var(--space-4);display:flex;align-items:center;gap:var(--space-2);border-bottom:1px solid var(--color-gray-100)}.code-card__name{font-size:var(--text-sm);font-weight:600;color:var(--color-gray-700)}.code-card__separator{color:var(--color-gray-300);font-weight:400}.code-card__code{display:flex;justify-content:center;gap:var(--space-2);padding:var(--space-4) var(--space-3)}.code-card__word{font-family:var(--font-mono);font-size:1.35rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;padding:var(--space-2) var(--space-3);background:var(--color-gray-50);border:1px solid var(--color-gray-200);border-radius:var(--radius-sm);color:var(--color-gray-800)}@media(max-width:768px){.codes-panel__grid{grid-template-columns:1fr}.code-card__word{font-size:1.2rem}}@media(max-width:480px){.code-card__word{font-size:1.05rem;padding:var(--space-1) var(--space-2)}.code-card__code{padding:var(--space-3) var(--space-2)}}.detail{max-width:900px;margin:0 auto;padding:var(--space-6);display:flex;flex-direction:column;gap:var(--space-6)}.detail__empty{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;text-align:center;padding:var(--space-8);color:var(--color-gray-400)}.detail__empty-icon{margin-bottom:var(--space-4);color:var(--color-gray-300)}.detail__empty h2{margin:0 0 var(--space-2);font-size:var(--text-xl);font-weight:600;color:var(--color-gray-500)}.detail__empty p{margin:0 0 var(--space-5);font-size:var(--text-sm);color:var(--color-gray-400)}.detail__empty-sidebar-btn{padding:var(--space-2) var(--space-5);border:1px dashed var(--color-primary-300);border-radius:var(--radius-md);background:none;color:var(--color-primary-500);font-size:var(--text-sm);font-weight:500;transition:all var(--transition-fast)}.detail__empty-sidebar-btn:hover{background:var(--color-primary-50);border-style:solid}.detail__header{display:flex;flex-direction:column;gap:var(--space-4)}.detail__name{margin:0;font-size:var(--text-xl);font-weight:700;color:var(--color-gray-900)}.detail__description{margin:var(--space-1) 0 0;font-size:var(--text-sm);color:var(--color-gray-500);line-height:1.5}.detail__meta{display:flex;align-items:center;gap:var(--space-3);margin-top:var(--space-1)}.detail__member-count{font-size:var(--text-xs);color:var(--color-gray-400)}.detail__owner-badge{font-size:var(--text-xs);font-weight:600;color:var(--color-primary-600);background:var(--color-primary-50);padding:2px var(--space-2);border-radius:var(--radius-full)}.detail__invite{display:flex;align-items:center;gap:var(--space-2);flex-wrap:wrap}.detail__invite-input{flex:1;min-width:200px;padding:var(--space-2) var(--space-3);border:1px solid var(--color-gray-200);border-radius:var(--radius-sm);font-size:16px}.detail__invite-input:focus{outline:none;border-color:var(--color-primary-500);box-shadow:0 0 0 2px var(--color-primary-100)}.detail__invite-btn{padding:var(--space-2) var(--space-4);border:none;border-radius:var(--radius-sm);background:var(--color-primary-500);color:#fff;font-size:var(--text-sm);font-weight:500;white-space:nowrap;transition:background var(--transition-fast)}.detail__invite-btn:hover:not(:disabled){background:var(--color-primary-600)}.detail__invite-btn:disabled{opacity:.5;cursor:not-allowed}.detail__invite-status{font-size:var(--text-xs);font-weight:500;width:100%}.detail__invite-status--success{color:var(--color-success)}.detail__invite-status--error{color:var(--color-error)}.detail__section{display:flex;flex-direction:column}.detail__section-title{margin:0;padding-bottom:var(--space-2);font-size:var(--text-base);font-weight:600;color:var(--color-gray-700)}.detail__members{display:flex;flex-direction:column;gap:var(--space-2);padding-top:var(--space-2)}.member{display:flex;align-items:center;justify-content:space-between;padding:var(--space-3) var(--space-4);background:var(--color-gray-50);border-radius:var(--radius-sm)}.member__info{display:flex;flex-direction:column;min-width:0}.member__name{font-size:var(--text-sm);font-weight:500;color:var(--color-gray-900)}.member__email{font-size:var(--text-xs);color:var(--color-gray-400);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.member__actions{display:flex;align-items:center;gap:var(--space-2);flex-shrink:0}.member__role{font-size:var(--text-xs);font-weight:500;padding:2px var(--space-2);border-radius:var(--radius-full);background:var(--color-gray-100);color:var(--color-gray-500)}.member__role--owner{background:var(--color-primary-50);color:var(--color-primary-600)}.member__remove{width:32px;height:32px;padding:0;border:none;border-radius:var(--radius-full);background:none;color:var(--color-gray-400);font-size:var(--text-lg);line-height:1;display:flex;align-items:center;justify-content:center;transition:all var(--transition-fast)}.member__remove:hover{background:var(--color-error);color:#fff}.member--pending{background:#fff;border:1px dashed var(--color-gray-200)}.member__name--pending{color:var(--color-gray-500);font-style:italic}.member__role--pending{background:#fef3c7;color:var(--color-warning)}@media(max-width:768px){.detail{padding:var(--space-4)}.detail__invite{flex-direction:column}.detail__invite-input,.detail__invite-btn{width:100%}}@media(max-width:480px){.detail{padding:var(--space-3);gap:var(--space-4)}.detail__name{font-size:var(--text-lg)}}.app-shell{display:grid;grid-template-rows:var(--topbar-height) 1fr;grid-template-columns:var(--sidebar-width) 1fr;height:100vh;overflow:hidden}.app-shell__topbar{grid-column:1 / -1}.app-shell__sidebar{grid-row:2;overflow-y:auto;border-right:1px solid var(--color-gray-200);background:#fff}.app-shell__main{grid-row:2;overflow-y:auto;background:var(--color-gray-50)}.app-shell__overlay{display:none}@media(max-width:768px){.app-shell{grid-template-columns:1fr}.app-shell__sidebar{position:fixed;top:var(--topbar-height);left:0;bottom:0;width:var(--sidebar-width-mobile);z-index:50;transform:translate(-100%);transition:transform var(--transition-slow);box-shadow:var(--shadow-xl)}.app-shell__sidebar--open{transform:translate(0)}.app-shell__overlay{display:none;position:fixed;inset:0;top:var(--topbar-height);background:#0000004d;z-index:49}.app-shell__overlay--visible{display:block}}.loading-container{display:flex;flex-direction:column;justify-content:center;align-items:center;min-height:100vh;gap:20px}.loading-spinner{display:inline-block;position:relative;width:60px;height:60px}.loading-spinner div{position:absolute;border:4px solid var(--color-primary-500);opacity:1;border-radius:50%;animation:ripple 1s cubic-bezier(0,.2,.8,1) infinite}.loading-spinner div:nth-child(2){animation-delay:-.5s}.loading-spinner div:nth-child(3){animation-delay:-1s}.loading-spinner div:nth-child(4){animation-delay:-1.5s}@keyframes ripple{0%{top:25px;left:25px;width:0;height:0;opacity:1}to{top:0;left:0;width:60px;height:60px;opacity:0}}.loading-container p{color:var(--color-primary-500);font-weight:600;font-size:var(--text-lg)}
