@layer theme{:root,:host{--font-sans:ui-sans-serif, system-ui, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji";--font-mono:ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace;--shadow-sm:0 1px 3px 0 #0000001a, 0 1px 2px -1px #0000001a;--shadow-md:0 4px 6px -1px #0000001a, 0 2px 4px -2px #0000001a;--shadow-lg:0 10px 15px -3px #0000001a, 0 4px 6px -4px #0000001a;--default-font-family:var(--font-sans);--default-mono-font-family:var(--font-mono)}}@layer base{*,:after,:before,::backdrop{box-sizing:border-box;border:0 solid;margin:0;padding:0}::file-selector-button{box-sizing:border-box;border:0 solid;margin:0;padding:0}html,:host{-webkit-text-size-adjust:100%;tab-size:4;line-height:1.5;font-family:var(--default-font-family,ui-sans-serif, system-ui, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji");font-feature-settings:var(--default-font-feature-settings,normal);font-variation-settings:var(--default-font-variation-settings,normal);-webkit-tap-highlight-color:transparent}hr{height:0;color:inherit;border-top-width:1px}abbr:where([title]){-webkit-text-decoration:underline dotted;text-decoration:underline dotted}h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit}a{color:inherit;-webkit-text-decoration:inherit;-webkit-text-decoration:inherit;-webkit-text-decoration:inherit;-webkit-text-decoration:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,samp,pre{font-family:var(--default-mono-font-family,ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace);font-feature-settings:var(--default-mono-font-feature-settings,normal);font-variation-settings:var(--default-mono-font-variation-settings,normal);font-size:1em}small{font-size:80%}sub,sup{vertical-align:baseline;font-size:75%;line-height:0;position:relative}sub{bottom:-.25em}sup{top:-.5em}table{text-indent:0;border-color:inherit;border-collapse:collapse}:-moz-focusring{outline:auto}progress{vertical-align:baseline}summary{display:list-item}ol,ul,menu{list-style:none}img,svg,video,canvas,audio,iframe,embed,object{vertical-align:middle;display:block}img,video{max-width:100%;height:auto}button,input,select,optgroup,textarea{font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;color:inherit;opacity:1;background-color:#0000;border-radius:0}::file-selector-button{font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;color:inherit;opacity:1;background-color:#0000;border-radius:0}:where(select:is([multiple],[size])) optgroup{font-weight:bolder}:where(select:is([multiple],[size])) optgroup option{padding-inline-start:20px}::file-selector-button{margin-inline-end:4px}::placeholder{opacity:1}@supports (not ((-webkit-appearance:-apple-pay-button))) or (contain-intrinsic-size:1px){::placeholder{color:currentColor}@supports (color:color-mix(in lab, red, red)){::placeholder{color:color-mix(in oklab, currentcolor 50%, transparent)}}}textarea{resize:vertical}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-date-and-time-value{min-height:1lh;text-align:inherit}::-webkit-datetime-edit{display:inline-flex}::-webkit-datetime-edit-fields-wrapper{padding:0}::-webkit-datetime-edit{padding-block:0}::-webkit-datetime-edit-year-field{padding-block:0}::-webkit-datetime-edit-month-field{padding-block:0}::-webkit-datetime-edit-day-field{padding-block:0}::-webkit-datetime-edit-hour-field{padding-block:0}::-webkit-datetime-edit-minute-field{padding-block:0}::-webkit-datetime-edit-second-field{padding-block:0}::-webkit-datetime-edit-millisecond-field{padding-block:0}::-webkit-datetime-edit-meridiem-field{padding-block:0}::-webkit-calendar-picker-indicator{line-height:1}:-moz-ui-invalid{box-shadow:none}button,input:where([type=button],[type=reset],[type=submit]){appearance:button}::file-selector-button{appearance:button}::-webkit-inner-spin-button{height:auto}::-webkit-outer-spin-button{height:auto}[hidden]:where(:not([hidden=until-found])){display:none!important}}@layer components;@layer utilities{.visible{visibility:visible}.container{width:100%}@media (min-width:40rem){.container{max-width:40rem}}@media (min-width:48rem){.container{max-width:48rem}}@media (min-width:64rem){.container{max-width:64rem}}@media (min-width:80rem){.container{max-width:80rem}}@media (min-width:96rem){.container{max-width:96rem}}.flex{display:flex}.grid{display:grid}.hidden{display:none}.inline{display:inline}.min-h-screen{min-height:100vh}.antialiased{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}}:root{--brand-50:#fdf2f2;--brand-100:#fce4e4;--brand-200:#f9c8c8;--brand-300:#f19999;--brand-400:#e16868;--brand-500:#c73838;--brand-600:#991b1b;--brand-700:#7a1515;--brand-800:#5c1010;--brand-900:#3d0a0a;--cream-50:#fffceb;--cream-100:#fef3c7;--cream-200:#fde9a4;--neutral-50:#faf9f7;--neutral-100:#f0eeea;--neutral-200:#ddd9d2;--neutral-300:#b8b2a8;--neutral-500:#76716a;--neutral-700:#3f3c37;--neutral-900:#1a1816;--color-success-bg:#dcfce7;--color-success-text:#15803d;--color-warning-bg:#fef3c7;--color-warning-text:#a16207;--color-danger-bg:#fee2e2;--color-danger-text:#b91c1c;--color-info-bg:#e0f2fe;--color-info-text:#0369a1;--bg-page:var(--cream-50);--bg-surface:#fff;--bg-elevated:var(--cream-100);--text-primary:var(--brand-800);--text-secondary:var(--neutral-500);--border-default:var(--neutral-200);--accent:var(--brand-600);--accent-hover:var(--brand-700);--shadow-sm:0 1px 2px #3d0a0a0a;--shadow-md:0 4px 14px #3d0a0a14;--shadow-lg:0 10px 30px #3d0a0a1a}*{box-sizing:border-box}body{background:var(--bg-page);min-height:100vh;color:var(--text-primary);padding:20px 10px;font-family:-apple-system,BlinkMacSystemFont,Inter,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif}a{color:inherit;text-decoration:none}.container{max-width:1100px;margin:0 auto}.container-narrow{max-width:440px;margin:0 auto}.frithon-logo{vertical-align:middle;align-items:center;gap:10px;display:inline-flex}.frithon-logo .wordmark{letter-spacing:-.01em;color:var(--brand-600);font-size:1.6rem;font-weight:500}.frithon-logo .wordmark.lg{font-size:2.2rem}.btn{cursor:pointer;border:none;border-radius:10px;align-items:center;gap:6px;padding:10px 20px;font-size:.95rem;font-weight:500;transition:background .15s,color .15s;display:inline-flex}.btn-primary{background:var(--brand-600);color:var(--cream-100)}.btn-primary:hover{background:var(--brand-700)}.btn-primary:disabled{opacity:.6;cursor:not-allowed}.btn-secondary{background:var(--bg-elevated);color:var(--text-primary);border:.5px solid var(--border-default)}.btn-secondary:hover{background:var(--cream-200)}.btn-danger{background:var(--color-danger-text);color:var(--cream-100)}.btn-danger:hover{background:#7f1d1d}.btn-block{justify-content:center;width:100%;margin-top:10px;padding:14px;font-size:1rem}.btn-sm{border-radius:8px;padding:6px 12px;font-size:.82rem}.field-label{color:var(--neutral-700);margin-top:12px;margin-bottom:5px;font-size:.78rem;font-weight:500;display:block}.field-label:first-of-type{margin-top:0}.field{border:2px solid var(--border-default);background:var(--bg-surface);width:100%;color:var(--text-primary);border-radius:10px;outline:none;padding:11px 14px;font-family:inherit;font-size:1rem;transition:border .15s}.field:focus{border-color:var(--brand-600)}.field-hint{color:var(--neutral-300);margin-top:4px;font-size:.74rem}.auth-card{background:var(--bg-surface);box-shadow:var(--shadow-lg);border:.5px solid var(--border-default);border-radius:16px;margin-top:40px;padding:32px 28px}.auth-logo{text-align:center;justify-content:center;align-items:center;gap:12px;margin-bottom:14px;display:flex}.auth-logo .brand-name{color:var(--brand-600);letter-spacing:-.02em;font-size:2rem;font-weight:500}.auth-card h2{color:var(--text-primary);text-align:center;margin-bottom:6px;font-size:1.5rem;font-weight:500}.auth-card .auth-sub{color:var(--text-secondary);text-align:center;margin-bottom:22px;font-size:.92rem}.auth-toggle{text-align:center;color:var(--text-secondary);margin-top:18px;font-size:.88rem}.auth-toggle a{color:var(--brand-600);font-weight:500;text-decoration:underline}.auth-error{background:var(--color-danger-bg);color:var(--color-danger-text);border-radius:10px;margin-bottom:14px;padding:10px 13px;font-size:.88rem}.auth-ok{background:var(--color-success-bg);color:var(--color-success-text);border-radius:10px;margin-bottom:14px;padding:10px 13px;font-size:.88rem}header{text-align:center;margin-bottom:20px;padding:14px;position:relative}header h1{letter-spacing:-.02em;color:var(--brand-600);font-size:2.2rem;font-weight:500}header p{color:var(--text-secondary);margin-top:8px;font-size:.95rem}.user-bar{background:var(--bg-surface);box-shadow:var(--shadow-md);border:.5px solid var(--border-default);border-radius:14px;flex-wrap:wrap;justify-content:space-between;align-items:center;gap:10px;margin-bottom:16px;padding:10px 16px;font-size:.9rem;display:flex}.user-bar .who{align-items:center;gap:10px;display:flex}.user-bar .avatar{background:var(--brand-600);width:36px;height:36px;color:var(--cream-100);border-radius:50%;justify-content:center;align-items:center;font-weight:500;display:flex}.user-bar .name{color:var(--text-primary);font-weight:500}.user-bar .role-badge{background:var(--color-warning-bg);color:var(--color-warning-text);text-transform:uppercase;letter-spacing:.04em;border-radius:10px;margin-left:6px;padding:2px 8px;font-size:.7rem;font-weight:500}.logout-btn{border:1px solid var(--brand-300);color:var(--brand-600);cursor:pointer;background:0 0;border-radius:8px;padding:6px 12px;font-size:.85rem;font-weight:500;transition:background .15s,color .15s}.logout-btn:hover{background:var(--brand-600);color:var(--cream-100);border-color:var(--brand-600)}.legend-row{flex-wrap:wrap;justify-content:center;align-items:center;gap:8px;margin:14px 0 22px;display:flex}.legend-item{background:var(--bg-surface);box-shadow:var(--shadow-sm);border:.5px solid var(--border-default);color:var(--text-primary);border-radius:20px;align-items:center;gap:7px;padding:7px 14px;font-size:.85rem;display:flex}.legend-dot{border-radius:50%;width:12px;height:12px}.info-btn{background:var(--bg-surface);border:.5px solid var(--border-default);width:32px;height:32px;color:var(--brand-600);cursor:pointer;border-radius:50%;justify-content:center;align-items:center;font-size:1rem;font-weight:500;display:inline-flex}.info-btn:hover{background:var(--brand-50)}.tabs{flex-wrap:wrap;justify-content:center;gap:6px;margin-bottom:18px;display:flex}.tab{background:var(--bg-surface);border:.5px solid var(--border-default);cursor:pointer;color:var(--text-primary);border-radius:22px;padding:10px 16px;font-size:.9rem;font-weight:500}.tab:hover{background:var(--bg-elevated);border-color:var(--brand-200)}.tab.active{background:var(--brand-600);color:var(--cream-100);border-color:var(--brand-600);box-shadow:var(--shadow-md)}.tab.admin-only{background:var(--color-warning-bg);color:var(--color-warning-text);border-color:#0000}.tab.admin-only.active{background:var(--brand-700);color:var(--cream-100);border-color:var(--brand-700)}.week{background:var(--bg-surface);box-shadow:var(--shadow-lg);border:.5px solid var(--border-default);border-radius:16px;margin-bottom:18px;overflow:hidden}.week-header{background:var(--brand-600);color:var(--cream-100);flex-wrap:wrap;justify-content:space-between;align-items:center;gap:8px;padding:14px 22px;font-size:1.05rem;font-weight:500;display:flex}.week-header .date-line,.week-header-right{align-items:center;gap:10px;display:flex}.chevron-btn{color:var(--cream-100);cursor:pointer;background:0 0;border:none;align-items:center;padding:2px 4px;font-size:1rem;line-height:1;display:flex}.chevron{opacity:.85;transition:transform .2s}.week.collapsed .chevron{transform:rotate(-90deg)}.filled-stat{background:#fef3c733;border-radius:12px;padding:4px 12px;font-size:.82rem;font-weight:500}.filled-stat.full{background:var(--color-success-text);color:var(--cream-100)}.filled-stat.empty{background:var(--color-danger-text);color:var(--cream-100)}.coord-badge{background:var(--cream-200);color:var(--brand-800);border-radius:10px;padding:2px 10px;font-size:.72rem;font-weight:500}.coord-control{flex-wrap:wrap;align-items:center;gap:6px;margin:0;display:flex}.coord-select{border:1px solid var(--cream-200);background:var(--cream-100);color:var(--brand-800);border-radius:8px;max-width:170px;padding:3px 6px;font-size:.75rem}.coord-save-btn{background:var(--cream-100);color:var(--brand-700);cursor:pointer;border:none;border-radius:8px;padding:3px 9px;font-size:.72rem;font-weight:600}.coord-save-btn:hover{background:var(--cream-200)}.coord-err{color:var(--cream-100);background:var(--color-danger-text);border-radius:8px;padding:2px 7px;font-size:.66rem}.week-body{background:var(--bg-surface);padding:14px 22px 20px}.group{margin-top:12px}.group:first-child{margin-top:2px}.group-title{text-transform:uppercase;letter-spacing:1.2px;color:var(--text-secondary);align-items:center;gap:8px;margin-bottom:7px;font-size:.78rem;font-weight:500;display:flex}.group-title:before{content:"";background:var(--brand-600);border-radius:2px;width:4px;height:14px}.positions{grid-template-columns:repeat(auto-fill,minmax(170px,1fr));gap:8px;display:grid}.slot{background:var(--bg-elevated);border:2px solid #0000;border-radius:10px;flex-direction:column;justify-content:center;gap:3px;min-height:58px;padding:9px 13px;transition:all .2s;display:flex;position:relative;overflow:hidden}.slot-position{color:var(--text-secondary);text-transform:uppercase;letter-spacing:.4px;word-break:break-word;font-size:.68rem;font-weight:500}.slot-name{color:var(--text-primary);word-break:break-word;font-size:.92rem;font-weight:500}.slot.has-name{background:var(--bg-surface);border-color:var(--border-default)}.slot.is-mine{border-color:var(--brand-600);box-shadow:0 0 0 3px #991b1b26}.slot.empty.signup{border:2px dashed var(--color-danger-text);background:var(--color-danger-bg);cursor:pointer;animation:2.5s ease-in-out infinite pulseRed}.slot.empty.signup:hover{border-color:var(--brand-700);background:#ffe5e5;animation:none}.slot.empty.signup .slot-name{color:var(--color-danger-text);font-weight:500}.slot.empty.signup .slot-position{color:var(--color-danger-text)}@keyframes pulseRed{0%,to{box-shadow:0 0 #b91c1c00}50%{box-shadow:0 0 0 4px #b91c1c2e}}.slot.empty.readonly{border:2px dashed var(--neutral-200);background:var(--neutral-50);opacity:.75}.slot.empty.readonly .slot-name{color:var(--neutral-300);font-style:italic}.slot-form{margin:0}.slot-remove{background:var(--color-danger-text);color:var(--cream-100);cursor:pointer;border:none;border-radius:50%;width:18px;height:18px;font-size:11px;font-weight:500;line-height:1;position:absolute;top:4px;right:6px}.slot-err{color:var(--color-danger-text);margin-top:2px;font-size:.66rem}.slot.empty.signup.managed{cursor:default;gap:5px}.slot-target{border:1px solid var(--border-default);background:var(--bg-surface);width:100%;color:var(--text-primary);border-radius:6px;padding:4px 6px;font-size:.8rem}.slot-add-btn{background:var(--brand-600);color:var(--cream-100);cursor:pointer;border:none;border-radius:6px;align-self:flex-start;padding:4px 10px;font-size:.78rem;font-weight:500;transition:background .15s}.slot-add-btn:hover{background:var(--brand-700)}.card{background:var(--bg-surface);box-shadow:var(--shadow-lg);border:.5px solid var(--border-default);border-radius:16px;margin-bottom:18px;padding:22px}.card h2{color:var(--text-primary);margin-bottom:14px;font-size:1.3rem;font-weight:500}.top-list{gap:6px;display:grid}.top-item{background:var(--bg-elevated);border-left:4px solid #0000;border-radius:10px;align-items:center;gap:12px;padding:10px 14px;display:flex}.top-rank{color:var(--text-secondary);text-align:center;min-width:30px;font-weight:500}.top-rank.gold{color:var(--color-warning-text)}.top-rank.silver{color:var(--neutral-500)}.top-rank.bronze{color:#b45309}.top-name{color:var(--text-primary);flex-grow:1;font-weight:500}.top-count{background:var(--brand-600);color:var(--cream-100);border-radius:12px;padding:3px 10px;font-size:.85rem;font-weight:500}.team-list{grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:8px;display:grid}.team-person{background:var(--bg-elevated);border-left:4px solid #0000;border-radius:10px;padding:11px 15px}.team-person .name{color:var(--text-primary);font-weight:500}.team-person .meta{color:var(--text-secondary);margin-top:3px;font-size:.78rem}.team-person .contact{color:var(--neutral-700);margin-top:4px;font-size:.78rem}.team-person .status{margin-top:4px;font-size:.78rem;font-weight:500}.lvl-red{border-left-color:var(--color-danger-text)}.lvl-red .status{color:var(--color-danger-text)}.lvl-yellow{border-left-color:var(--color-warning-text)}.lvl-yellow .status{color:var(--color-warning-text)}.lvl-green{border-left-color:var(--color-success-text)}.lvl-green .status{color:var(--color-success-text)}.lvl-blue{border-left-color:var(--color-info-text)}.lvl-blue .status{color:var(--color-info-text)}.lvl-normal{border-left-color:var(--neutral-200)}.lvl-normal .status{color:var(--text-secondary)}.list{gap:8px;display:grid}.list-row{background:var(--bg-elevated);border-radius:10px;flex-wrap:wrap;justify-content:space-between;align-items:center;gap:12px;padding:11px 15px;display:flex}.muted{color:var(--text-secondary);font-size:.85rem}.section-link{background:var(--bg-surface);border:.5px solid var(--border-default);box-shadow:var(--shadow-sm);border-radius:14px;margin-bottom:10px;padding:16px 18px;display:block}.section-link:hover{box-shadow:var(--shadow-md);border-color:var(--brand-200)}.stat-grid{grid-template-columns:repeat(3,1fr);gap:10px;margin-bottom:18px;display:grid}.stat{background:var(--bg-surface);text-align:center;box-shadow:var(--shadow-sm);border:.5px solid var(--border-default);border-radius:14px;padding:16px}.stat .num{color:var(--brand-700);font-size:1.6rem;font-weight:500}.stat .lbl{color:var(--text-secondary);font-size:.75rem}.history-card{overflow-x:auto}.history-table{border-collapse:collapse;width:100%;font-size:.85rem}.history-table th{text-align:left;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.4px;border-bottom:1px solid var(--border-default);padding:6px 10px;font-size:.72rem;font-weight:500}.history-table td{border-bottom:.5px solid var(--border-default);color:var(--text-primary);vertical-align:top;padding:8px 10px}.history-table tr:last-child td{border-bottom:none}.history-table .nowrap{white-space:nowrap}.modal-overlay{z-index:100;background:#3d0a0a73;justify-content:center;align-items:center;padding:20px;display:flex;position:fixed;inset:0}.modal{background:var(--bg-surface);width:100%;max-width:420px;box-shadow:var(--shadow-lg);border:.5px solid var(--border-default);border-radius:16px;padding:24px}.modal h3{color:var(--text-primary);margin-bottom:16px;font-size:1.2rem;font-weight:500}.color-info-list{gap:12px;margin-bottom:18px;display:grid}.color-info-item{align-items:flex-start;gap:10px;display:flex}.color-info-item .legend-dot{flex-shrink:0;margin-top:4px}.cii-title{color:var(--text-primary);font-size:.92rem;font-weight:500}.cii-desc{color:var(--text-secondary);margin-top:2px;font-size:.82rem}
