@import"https://fonts.googleapis.com/css2?family=Plus+Jakarta+Sans:ital,wght@0,400;0,500;0,600;0,700;1,400&display=swap";/*! tailwindcss v4.2.2 | MIT License | https://tailwindcss.com */@layer properties{@supports (((-webkit-hyphens:none)) and (not (margin-trim:inline))) or ((-moz-orient:inline) and (not (color:rgb(from red r g b)))){*,:before,:after,::backdrop{--tw-blur:initial;--tw-brightness:initial;--tw-contrast:initial;--tw-grayscale:initial;--tw-hue-rotate:initial;--tw-invert:initial;--tw-opacity:initial;--tw-saturate:initial;--tw-sepia:initial;--tw-drop-shadow:initial;--tw-drop-shadow-color:initial;--tw-drop-shadow-alpha:100%;--tw-drop-shadow-size:initial}}}@layer theme{:root,:host{--font-sans:"Plus Jakarta Sans", system-ui, -apple-system, sans-serif;--font-mono:ui-monospace, "SF Mono", "Consolas", monospace;--color-stone-50:#faf8f4;--color-stone-100:#f2efe8;--color-stone-200:#ded9d0;--color-stone-300:#c8c2b8;--color-stone-400:#a09890;--color-stone-500:#7c7570;--color-stone-600:#5c5650;--color-stone-900:#1c1814;--spacing:.25rem;--radius-xs:5px;--radius-sm:8px;--radius-md:12px;--radius-lg:16px;--radius-xl:20px;--radius-2xl:24px;--shadow-xs:0 1px 2px #1c160e0d;--shadow-sm:0 1px 3px #1c160e12, 0 1px 2px #1c160e0a;--shadow-md:0 4px 12px #1c160e12, 0 1px 4px #1c160e0a;--shadow-lg:0 8px 28px #1c160e17, 0 3px 8px #1c160e0d;--default-font-family:var(--font-sans);--default-mono-font-family:var(--font-mono);--color-forest-50:#eef7f2;--color-forest-100:#d4ebda;--color-forest-200:#a8d4b3;--color-forest-400:#3a8a5e;--color-forest-600:#236840;--color-forest-700:#1b4d32;--color-gold-50:#fef9ec;--color-gold-100:#fcefc4;--color-gold-300:#e8bc56;--color-gold-500:#c8921c;--color-gold-700:#8a6010;--color-stone-150:#eae6de;--color-bg:#f0ede4;--color-surface:#fff;--color-border:#e0ddd5;--color-ok-bg:#e8f5d5;--color-ok-text:#275c10;--color-ok-ring:#7ab83a;--color-no-bg:#fdeeed;--color-no-text:#7a2020;--color-no-ring:#e09090;--color-warn-bg:#fdf3e3;--color-warn-text:#7a4c10;--shadow-modal:0 32px 80px #1c160e2e, 0 10px 28px #1c160e1a;--radius-full:9999px}}@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%;-moz-tab-size:4;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;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]){-webkit-appearance:button;-moz-appearance:button;appearance:button}::file-selector-button{-webkit-appearance:button;-moz-appearance: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}.mt-2{margin-top:calc(var(--spacing) * 2)}.mt-3{margin-top:calc(var(--spacing) * 3)}.mb-1{margin-bottom:calc(var(--spacing) * 1)}.mb-2{margin-bottom:calc(var(--spacing) * 2)}.mb-4{margin-bottom:calc(var(--spacing) * 4)}.flex{display:flex}.inline{display:inline}.w-full{width:100%}.flex-1{flex:1}.shrink-0{flex-shrink:0}.text-\[10px\]{font-size:10px}.filter{filter:var(--tw-blur,) var(--tw-brightness,) var(--tw-contrast,) var(--tw-grayscale,) var(--tw-hue-rotate,) var(--tw-invert,) var(--tw-saturate,) var(--tw-sepia,) var(--tw-drop-shadow,)}}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth}body{font-family:var(--font-sans);background-color:var(--color-bg);color:var(--color-stone-900);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;min-height:100svh}body:before{content:"";pointer-events:none;z-index:0;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='200' height='200'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='200' height='200' filter='url(%23n)' opacity='0.03'/%3E%3C/svg%3E");position:fixed;top:0;right:0;bottom:0;left:0}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:var(--color-stone-300);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--color-stone-400)}.num{font-variant-numeric:tabular-nums;font-feature-settings:"tnum"}.app-nav{background:var(--color-surface);border-bottom:1px solid var(--color-border);box-shadow:var(--shadow-xs);z-index:50;position:sticky;top:0}.nav-top{align-items:center;gap:8px;height:52px;padding:0 1rem;display:flex}.nav-brand{color:var(--color-forest-700);letter-spacing:-.025em;border-right:1px solid var(--color-border);flex-shrink:0;align-items:center;gap:8px;padding-right:16px;font-size:15px;font-weight:700;display:flex}.nav-brand-icon{background:var(--color-forest-700);border-radius:var(--radius-sm);color:#fff;flex-shrink:0;justify-content:center;align-items:center;width:28px;height:28px;font-size:14px;display:flex}.nav-right{flex-shrink:0;align-items:center;gap:8px;margin-left:auto;display:flex}.user-chip{background:var(--color-stone-50);border:1px solid var(--color-border);border-radius:var(--radius-full);cursor:pointer;align-items:center;gap:7px;padding:4px 10px 4px 4px;transition:background .12s;display:flex}.user-chip:hover{background:var(--color-forest-50);border-color:var(--color-forest-200)}.user-avatar{background:var(--color-forest-700);color:#fff;letter-spacing:0;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:24px;height:24px;font-size:11px;font-weight:700;display:flex}.user-name{color:var(--color-stone-600);text-overflow:ellipsis;white-space:nowrap;max-width:130px;font-size:12px;font-weight:500;overflow:hidden}.logout-btn{border:1px solid var(--color-border);border-radius:var(--radius-sm);background:var(--color-surface);color:var(--color-stone-500);cursor:pointer;flex-shrink:0;align-items:center;gap:5px;padding:6px 10px;font-family:inherit;font-size:12px;font-weight:500;transition:background .12s,border-color .12s,color .12s;display:flex}.logout-btn:hover{background:var(--color-stone-50);border-color:var(--color-stone-300);color:var(--color-stone-900)}.logout-btn svg{flex-shrink:0}.nav-tabs-row{border-top:1px solid var(--color-stone-100);scrollbar-width:none;overflow-x:auto}.nav-tabs-row::-webkit-scrollbar{display:none}.nav-tabs{min-width:max-content;padding:0 1rem;display:flex}.nav-tab{color:var(--color-stone-400);cursor:pointer;white-space:nowrap;background:0 0;border:none;border-bottom:2px solid #0000;padding:10px 14px;font-family:inherit;font-size:13px;font-weight:500;transition:color .12s,border-color .12s}.nav-tab:hover{color:var(--color-stone-600)}.nav-tab.active{color:var(--color-forest-700);border-bottom-color:var(--color-forest-700);font-weight:600}.burger-btn{border:1px solid var(--color-border);border-radius:var(--radius-sm);cursor:pointer;width:34px;height:34px;color:var(--color-stone-600);background:0 0;flex-shrink:0;justify-content:center;align-items:center;transition:background .12s,border-color .12s;display:none}.burger-btn:hover{background:var(--color-stone-50)}.burger-btn.open{background:var(--color-forest-50);border-color:var(--color-forest-200);color:var(--color-forest-700)}.mobile-drawer{border-top:0 solid var(--color-border);max-height:0;transition:max-height .24s cubic-bezier(.4,0,.2,1);overflow:hidden}.mobile-drawer.open{border-top-width:1px;max-height:320px}.mobile-nav-tab{width:100%;color:var(--color-stone-600);border:none;border-bottom:1px solid var(--color-stone-100);cursor:pointer;text-align:left;background:0 0;align-items:center;padding:13px 20px;font-family:inherit;font-size:14px;font-weight:500;transition:background .12s,color .12s;display:flex}.mobile-nav-tab:last-child{border-bottom:none}.mobile-nav-tab:hover{background:var(--color-stone-50);color:var(--color-stone-900)}.mobile-nav-tab.active{color:var(--color-forest-700);background:var(--color-forest-50);border-left:3px solid var(--color-forest-700);padding-left:17px;font-weight:600}@media(max-width:600px){.app-nav{flex-direction:column;align-items:stretch}.nav-top{width:100%}.nav-tabs-row{display:none}.mobile-drawer{width:100%}.burger-btn{display:flex}.user-name{display:none}.user-chip{padding:4px}.logout-text{display:none}.logout-btn{padding:6px 8px}}@media(min-width:601px){.mobile-drawer,.burger-btn{display:none!important}}.main{z-index:1;max-width:860px;margin:0 auto;padding:1.25rem 1rem 3rem;position:relative}.page{display:none}.page.active{display:block}.card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);margin-bottom:1rem;padding:1.25rem;transition:box-shadow .2s}.card:hover{box-shadow:var(--shadow-md)}.card-sm{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);box-shadow:var(--shadow-xs);padding:1rem}.card-list{padding:0 .25rem}.section-hdr{color:var(--color-stone-400);text-transform:uppercase;letter-spacing:.07em;margin:1.25rem 0 .5rem;font-size:11px;font-weight:600}.field-label{color:var(--color-stone-400);text-transform:uppercase;letter-spacing:.06em;font-size:11.5px;font-weight:600}.filter-row{flex-wrap:wrap;align-items:center;gap:8px;margin-bottom:1rem;display:flex}.scoring-filter-group{flex:1;align-items:center;gap:8px;min-width:0;display:flex}@media(max-width:640px){.scoring-filter-row{flex-direction:column;align-items:stretch}.scoring-filter-group{width:100%}.score-table th.th-sub{font-size:0}}.filter-lbl{color:var(--color-stone-400);font-size:13px}.btn{border-radius:var(--radius-sm);border:1px solid var(--color-border);background:var(--color-surface);color:var(--color-stone-600);cursor:pointer;-webkit-user-select:none;user-select:none;align-items:center;gap:5px;padding:6px 14px;font-family:inherit;font-size:13px;font-weight:500;transition:background .12s,border-color .12s,color .12s,box-shadow .12s,transform 80ms;display:inline-flex}.btn:hover{background:var(--color-stone-50);border-color:var(--color-stone-300)}.btn:active{transform:scale(.97)}.btn-primary{background:var(--color-forest-700);color:#fff;border-color:var(--color-forest-700);box-shadow:0 1px 3px #1b4d3240}.btn-primary:hover{background:var(--color-forest-600);border-color:var(--color-forest-600);box-shadow:0 2px 6px #1b4d324d}.btn-primary:disabled{background:var(--color-stone-200);color:var(--color-stone-400);border-color:var(--color-stone-200);box-shadow:none;cursor:default}.btn-sm{border-radius:var(--radius-xs);padding:3px 9px;font-size:11.5px}.btn-danger{color:var(--color-no-text);border-color:var(--color-no-ring);background:var(--color-no-bg)}.btn-block{border-radius:var(--radius-md);justify-content:center;width:100%;height:46px;font-size:14px}.btn-icon{border-radius:50%;justify-content:center;width:28px;height:28px;padding:0}.btn-danger:hover{background:#fde8e7;border-color:#d07070}input[type=text],input[type=number],select,textarea{border:1px solid var(--color-border);border-radius:var(--radius-sm);background:var(--color-surface);color:var(--color-stone-900);outline:none;padding:7px 11px;font-family:inherit;font-size:13px;transition:border-color .12s,box-shadow .12s}input:focus,select:focus{border-color:var(--color-forest-400);box-shadow:0 0 0 3px #3a8a5e1f}select{-webkit-appearance:auto;-moz-appearance:auto;appearance:auto}.badge{border-radius:var(--radius-full);letter-spacing:.01em;align-items:center;padding:2px 8px;font-size:11px;font-weight:600;display:inline-flex}.badge-qual{color:#1a5ba8;background:#e4f1ff}.badge-elim{background:var(--color-warn-bg);color:var(--color-warn-text)}.badge-semi{color:#4038a8;background:#eeecfe}.badge-final{background:var(--color-no-bg);color:#8a1818}.badge-sabtu{background:var(--color-forest-50);color:var(--color-forest-700)}.badge-minggu{color:#4038a8;background:#eeecfe}.badge-done{background:var(--color-ok-bg);color:var(--color-ok-text)}.badge-active{color:#1a5ba8;background:#e4f1ff}.badge-wait{background:var(--color-stone-100);color:var(--color-stone-400)}.badge-lock{background:var(--color-stone-100);color:var(--color-stone-300)}table{border-collapse:collapse;width:100%;font-size:13px}th{color:var(--color-stone-400);text-align:left;border-bottom:1px solid var(--color-stone-100);letter-spacing:.03em;padding:6px 8px;font-size:11px;font-weight:600}td{border-bottom:1px solid var(--color-stone-100);color:var(--color-stone-900);padding:9px 8px}tr:last-child td{border-bottom:none}tbody tr{transition:background .1s}tbody tr:hover td{background:var(--color-stone-50)}.score-table{border-collapse:collapse;width:100%;font-size:13px}.score-table th{text-align:center;border-bottom:1px solid var(--color-stone-100);color:var(--color-stone-400);letter-spacing:.04em;text-transform:uppercase;padding:6px 4px;font-size:10.5px;font-weight:600}.score-table th.thl{text-align:left;padding-left:10px}.score-table td{text-align:center;border-bottom:1px solid var(--color-stone-100);padding:7px 3px}.score-table tr:last-child td{border-bottom:none}.score-table tbody tr{cursor:pointer;transition:background .1s}.score-table tbody tr:hover td{background:var(--color-stone-50)}.seri-lbl{color:var(--color-stone-600);white-space:nowrap;font-size:12px;font-weight:600;text-align:left!important;padding-left:12px!important}.grand-row td{background:var(--color-stone-50);padding:9px 4px;font-weight:600}.grand-lbl{color:var(--color-stone-400);text-transform:uppercase;letter-spacing:.04em;font-size:11px;text-align:left!important;padding-left:12px!important}.arrow-pill{border-radius:var(--radius-xs);font-variant-numeric:tabular-nums;background:var(--color-stone-100);min-width:28px;height:28px;color:var(--color-stone-400);justify-content:center;align-items:center;font-size:12px;font-weight:600;transition:background .12s;display:inline-flex}.pill-val{color:#1a5ba8;background:#e4f1ff}.pill-top{background:var(--color-gold-100);color:var(--color-gold-700)}.pill-m{background:var(--color-stone-100);color:var(--color-stone-300)}.sum-grid{grid-template-columns:repeat(3,1fr);gap:8px;margin-top:1rem;display:grid}.sum-card{background:var(--color-stone-50);border:1px solid var(--color-stone-150);border-radius:var(--radius-md);padding:12px 14px}.sum-lbl{color:var(--color-stone-400);margin-bottom:4px;font-size:11px;font-weight:500}.sum-val{letter-spacing:-.02em;color:var(--color-forest-700);font-variant-numeric:tabular-nums;font-size:22px;font-weight:700}.pin-dots{justify-content:center;gap:12px;margin:14px 0 18px;display:flex}.pin-dot{border:2px solid var(--color-stone-300);background:0 0;border-radius:50%;width:15px;height:15px;transition:background .15s,border-color .15s,transform .12s}.pin-dot.filled{background:var(--color-forest-700);border-color:var(--color-forest-700);transform:scale(1.1)}.pin-numpad{grid-template-columns:repeat(3,1fr);gap:8px;margin-bottom:14px;display:grid}.pin-btn{border-radius:var(--radius-md);border:1px solid var(--color-border);background:var(--color-stone-50);height:52px;color:var(--color-stone-900);cursor:pointer;box-shadow:var(--shadow-xs);font-family:inherit;font-size:20px;font-weight:600;transition:background 80ms,transform 80ms,box-shadow 80ms}.pin-btn:hover{background:var(--color-stone-100)}.pin-btn:active{background:var(--color-stone-200);box-shadow:none;transform:scale(.95)}.pin-btn-action{color:var(--color-stone-400);font-size:12px}.pin-dots-centered{justify-content:center;margin:12px 0 16px}.profile-pin-row{border-bottom:.5px solid var(--color-border);cursor:pointer;justify-content:space-between;align-items:center;padding:10px 0;display:flex}.profile-pin-row:last-of-type{border-bottom:none}.profile-pin-dots{gap:12px}.profile-pin-dots .pin-dot{width:12px;height:12px}.pin-row-active .pin-dot{border-color:var(--color-forest-600)}.pin-row-active .pin-dot.filled{background:var(--color-forest-600)}.numpad{flex-direction:column;gap:7px;margin-bottom:14px;display:flex}.np-row{gap:7px;display:grid}.np-btn{border-radius:var(--radius-md);border:1px solid var(--color-border);background:var(--color-stone-50);height:52px;color:var(--color-stone-900);cursor:pointer;box-shadow:var(--shadow-xs);font-family:inherit;font-size:17px;font-weight:600;transition:background 80ms,transform 80ms}.np-btn:hover{background:var(--color-stone-100)}.np-btn:active{background:var(--color-stone-150);box-shadow:none;transform:scale(.95)}.np-top{background:var(--color-gold-50);border-color:var(--color-gold-300);color:var(--color-gold-700)}.np-top:hover{background:var(--color-gold-100)}.np-m{color:var(--color-stone-400);font-size:15px}.np-del{color:var(--color-stone-400);font-size:12.5px;font-weight:500}.arrow-slots{grid-template-columns:repeat(6,1fr);gap:7px;margin-bottom:12px;display:grid}.arrow-slot{border:1.5px solid var(--color-border);border-radius:var(--radius-md);text-align:center;cursor:pointer;background:var(--color-stone-50);padding:8px 4px 6px;transition:border-color .12s,box-shadow .12s,background .12s}.arrow-slot:hover{background:var(--color-stone-100)}.arrow-slot.active{border-color:var(--color-forest-400);background:var(--color-surface);box-shadow:0 0 0 3px #3a8a5e26}.slot-lbl{color:var(--color-stone-300);letter-spacing:.04em;text-transform:uppercase;margin-bottom:4px;font-size:9.5px;font-weight:600}.slot-val{color:var(--color-stone-300);font-variant-numeric:tabular-nums;min-height:28px;font-size:20px;font-weight:700;line-height:28px}.arrow-slot.filled .slot-val{color:#1a5ba8}.arrow-slot.filled-top .slot-val{color:var(--color-gold-500)}.arrow-slot.filled-m .slot-val{color:var(--color-stone-300);font-size:15px}.modal-overlay{-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);z-index:200;background:#1c160e80;justify-content:center;align-items:flex-end;display:flex;position:fixed;top:0;right:0;bottom:0;left:0}.modal-sheet{background:var(--color-surface);border-radius:var(--radius-2xl) var(--radius-2xl) 0 0;width:100%;max-width:520px;max-height:92svh;box-shadow:var(--shadow-modal);padding:0 1.25rem 2rem;animation:.26s cubic-bezier(.32,.72,0,1) slideUp;overflow-y:auto}.modal-sheet:before{content:"";background:var(--color-stone-200);border-radius:2px;width:36px;height:4px;margin:12px auto 16px;display:block}@keyframes slideUp{0%{transform:translateY(100%)}to{transform:translateY(0)}}.modal-hidden{display:none!important}.modal-hdr{justify-content:space-between;align-items:center;margin-bottom:16px;display:flex}.modal-title{color:var(--color-stone-900);font-size:16px;font-weight:600}.modal-meta{color:var(--color-stone-400);margin-top:2px;font-size:12px}.modal-subtotal{text-align:right;color:var(--color-stone-400);margin-bottom:12px;font-size:13px}.modal-subtotal-val{color:var(--color-stone-900);font-size:15px;font-weight:500}.timeline{flex-direction:column;display:flex}.phase-block{align-items:stretch;gap:0;display:flex}.phase-connector{flex-direction:column;flex-shrink:0;align-items:center;width:32px;display:flex}.phase-dot{width:13px;height:13px;box-shadow:0 0 0 3px var(--color-surface),0 0 0 4px currentColor;border-radius:50%;flex-shrink:0;margin-top:19px}.phase-line{flex:1;width:2px;min-height:16px}.phase-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);flex:1;margin-bottom:12px;padding:1rem 1.125rem}.phase-card.active-phase{border-color:var(--color-forest-400);box-shadow:0 0 0 1px var(--color-forest-400),var(--shadow-sm)}.phase-card.done-phase{opacity:.65}.phase-card.locked-phase{opacity:.4}.locked-msg{color:var(--color-stone-400);padding:2px 0;font-size:12px;font-style:italic}.toggle-btn{border-radius:var(--radius-full);border:1.5px solid var(--color-border);background:var(--color-stone-50);color:var(--color-stone-400);cursor:pointer;padding:3px 10px;font-family:inherit;font-size:11.5px;font-weight:500;transition:all .12s}.toggle-btn:hover{background:var(--color-stone-100);border-color:var(--color-stone-300)}.toggle-lolos{border-color:var(--color-ok-ring);color:var(--color-ok-text);background:var(--color-ok-bg)}.toggle-lolos:hover{background:#d8f0c0}.toggle-gugur{border-color:var(--color-no-ring);color:var(--color-no-text);background:var(--color-no-bg)}.toggle-gugur:hover{background:#fcd8d7}.status-pill{border-radius:var(--radius-full);padding:2px 9px;font-size:11px;font-weight:600}.pill-lolos{background:var(--color-ok-bg);color:var(--color-ok-text)}.pill-gugur{background:var(--color-stone-100);color:var(--color-stone-500)}.pill-belum{background:var(--color-warn-bg);color:var(--color-warn-text)}.tl-row{border-radius:8px;align-items:center;gap:8px;margin-bottom:5px;padding:7px 8px;font-size:12px;display:flex}.tl-nama{text-overflow:ellipsis;white-space:nowrap;flex:1;min-width:0;font-weight:500;overflow:hidden}.tl-skor{color:#0c447c;font-size:13px;font-weight:500}.tl-skor-empty{color:#aaa;font-size:13px}.tl-actions{flex-shrink:0;align-items:center;gap:6px;display:flex}.tl-no{color:#aaa;font-size:11px}@media(max-width:640px){.tl-row{flex-direction:column;align-items:flex-start;gap:3px}.tl-nama{white-space:normal;width:100%}.tl-actions{width:100%}}.confirm-bar{border-top:1px solid var(--color-stone-100);flex-wrap:wrap;justify-content:space-between;align-items:center;gap:8px;margin-top:12px;padding-top:12px;display:flex}.check-done{color:var(--color-ok-text);align-items:center;gap:6px;margin-top:10px;font-size:12px;font-weight:500;display:flex}.check-circle{background:var(--color-ok-ring);border-radius:50%;flex-shrink:0;width:16px;height:16px}.peserta-flag-row{border-bottom:.5px solid var(--color-border);align-items:center;gap:8px;padding:9px 10px;display:flex}.pfi-info{flex:1;min-width:0}.pfi-name{flex-wrap:wrap;align-items:center;gap:6px;display:flex}.pfi-nama{font-size:13px;font-weight:500}.pfi-no{color:var(--color-stone-400);font-size:11px}.pfi-sub{color:var(--color-stone-400);margin-top:2px;font-size:11px}.pfi-edit-btn{color:var(--color-stone-500);padding:1px 7px;font-size:10.5px}.flag-steps{flex-shrink:0;align-items:center;gap:4px;display:flex}.step-btn{border-radius:var(--radius-sm);border:1px solid var(--color-border);background:var(--color-stone-50);color:var(--color-stone-500);cursor:pointer;padding:4px 10px;font-family:inherit;font-size:11.5px;font-weight:500;transition:all .12s}.step-btn:hover{background:var(--color-stone-100)}.step-btn.step-done{background:var(--color-ok-bg);border-color:var(--color-ok-ring);color:var(--color-ok-text)}.step-btn.step-done:hover{background:#d8f0c0}.step-btn.step-disabled{opacity:.3;cursor:default;pointer-events:none}.step-arrow{color:var(--color-stone-300);font-size:10px}.peserta-item{border:1px solid var(--color-border);border-radius:var(--radius-md);cursor:pointer;background:var(--color-surface);box-shadow:var(--shadow-xs);align-items:center;gap:10px;padding:9px 12px;transition:all .12s;display:flex}.peserta-item:hover{background:var(--color-stone-50);border-color:var(--color-stone-300);box-shadow:var(--shadow-sm)}.peserta-item.assigned{border-color:var(--color-forest-400);background:var(--color-forest-50);box-shadow:0 0 0 1px var(--color-forest-400)}.pi-check{border:1.5px solid var(--color-stone-300);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:20px;height:20px;transition:all .12s;display:flex}.peserta-item.assigned .pi-check{background:var(--color-forest-700);border-color:var(--color-forest-700)}.pi-dot{background:#fff;border-radius:50%;width:8px;height:8px;display:none}.peserta-item.assigned .pi-dot{display:block}.assign-list{flex-direction:column;gap:6px;max-height:320px;display:flex;overflow-y:auto}.bantalan-pill{border-radius:var(--radius-full);background:var(--color-forest-50);color:var(--color-forest-700);border:1px solid var(--color-forest-100);font-variant-numeric:tabular-nums;align-items:center;padding:2px 8px;font-size:11px;font-weight:700;display:inline-flex}.off-card{margin-bottom:8px}.off-hdr{justify-content:space-between;align-items:center;margin-bottom:8px;display:flex}.off-name{font-size:14px;font-weight:500}.off-count{color:var(--color-stone-400);font-size:12px}.off-empty{color:var(--color-stone-300);font-size:12px;font-style:italic}.off-peserta-row{background:var(--color-stone-50);border-radius:var(--radius-sm);align-items:center;gap:8px;margin-bottom:4px;padding:5px 8px;font-size:12px;display:flex}.off-pnama{text-overflow:ellipsis;white-space:nowrap;flex:1;min-width:0;font-weight:500;overflow:hidden}.off-level{flex-shrink:0;font-size:11px;font-weight:500}.off-level-belum{color:var(--color-stone-400)}.off-level-hadir{color:#185fa5}.off-level-daftar{color:var(--color-warn-text)}.off-level-alat{color:var(--color-ok-text)}.pp-row{border-bottom:.5px solid var(--color-border);align-items:center;gap:8px;padding:8px 10px;font-size:12px;display:flex}.pp-info{flex:1;align-items:center;gap:6px;min-width:0;display:flex}.pp-right{flex-shrink:0;align-items:center;gap:6px;display:flex}.pp-official{font-size:12px}.pp-assigned{color:var(--color-stone-500)}.pp-unassigned{color:var(--color-stone-300);font-style:italic}.pp-atur-btn{min-height:unset;padding:2px 8px;font-size:11px}@media(max-width:640px){.pp-row{flex-direction:column;align-items:flex-start;gap:3px}.pp-info{width:100%}.pp-right{width:100%;padding-left:2px}.pp-official{font-size:11px}}.assign-option-list{flex-direction:column;gap:4px;max-height:55vh;margin-top:4px;display:flex;overflow-y:auto}.assign-opt{border:1.5px solid var(--color-border);background:var(--color-surface);width:100%;color:var(--color-stone-900);text-align:left;cursor:pointer;border-radius:8px;justify-content:space-between;align-items:center;padding:10px 12px;font-size:13px;font-weight:500;transition:border-color .15s,background .15s;display:flex}.assign-opt:hover{border-color:var(--color-forest-400);background:var(--color-forest-50)}.assign-opt-selected{border-color:var(--color-forest-400);background:var(--color-forest-50);color:var(--color-forest-700)}.assign-opt-count{color:var(--color-stone-400);font-size:11px;font-weight:400}.page-action-hdr{justify-content:space-between;align-items:center;margin-bottom:.75rem;display:flex}.page-action-title{color:var(--color-stone-900);font-size:14px;font-weight:600}.pin-row{border-bottom:.5px solid var(--color-border);flex-wrap:wrap;align-items:center;gap:10px;padding:10px 12px;display:flex}.pin-row:last-child{border-bottom:none}.pin-row-info{flex:1;min-width:0}.pin-row-name{color:var(--color-stone-900);font-size:13px;font-weight:500}.pin-row-sub{color:var(--color-stone-400);margin-top:2px;font-size:11px}.pin-row-actions{flex-shrink:0;align-items:center;gap:6px;display:flex}.form-body{flex-direction:column;gap:14px;margin-bottom:16px;display:flex}.form-body .field-label{margin-bottom:5px;display:block}.form-body input,.form-body select{width:100%;display:block}.add-field{flex-direction:column;display:flex}.add-field-row{gap:8px;display:flex}.add-field-row .add-field{flex:1;min-width:0}.stat-row{grid-template-columns:repeat(4,1fr);gap:8px;margin-bottom:1rem;display:grid}.stat-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);box-shadow:var(--shadow-xs);padding:12px 14px}.stat-lbl{color:var(--color-stone-400);margin-bottom:4px;font-size:11px;font-weight:500}.stat-val{letter-spacing:-.03em;color:var(--color-stone-900);font-variant-numeric:tabular-nums;font-size:24px;font-weight:700}.toolbar{flex-wrap:wrap;align-items:center;gap:8px;margin-bottom:10px;display:flex}.search-wrap{flex:1;min-width:180px;position:relative}.search-wrap input{width:100%;padding-left:32px}.search-icon{width:14px;height:14px;color:var(--color-stone-400);pointer-events:none;position:absolute;top:50%;left:10px;transform:translateY(-50%)}.info-chip{border-radius:var(--radius-full);background:var(--color-stone-100);color:var(--color-stone-500);border:1px solid var(--color-stone-150);padding:2px 9px;font-size:11px;font-weight:500}.empty-state{text-align:center;color:var(--color-stone-400);padding:2rem 1rem;font-size:13px}.error-msg{color:var(--color-no-text);text-align:center;min-height:18px;margin-bottom:10px;font-size:12px;font-weight:500}.login-page{background:radial-gradient(ellipse 90% 60% at 50% -5%,#1b4d321a 0%,transparent 65%),var(--color-bg);min-height:100svh;margin:-1.25rem -1rem;padding:0}.login-page.active{flex-direction:column;display:flex}.login-inner{width:min(100%,420px);margin-left:auto;margin-right:auto;padding:0 1.25rem 3rem}.login-brand{text-align:center;padding:1.5rem 0 1.75rem}.login-brand-mark{background:var(--color-forest-700);border-radius:var(--radius-xl);justify-content:center;align-items:center;width:52px;height:52px;margin:0 auto 12px;font-size:24px;display:flex;box-shadow:0 4px 16px #1b4d324d}.login-title{letter-spacing:-.03em;color:var(--color-stone-900);font-size:22px;font-weight:700}.login-sub{color:var(--color-stone-400);margin-top:4px;font-size:13px;font-weight:400}.login-tab-switch{background:var(--color-stone-100);border:1px solid var(--color-stone-200);border-radius:var(--radius-lg);gap:4px;margin-bottom:1.25rem;padding:4px;display:flex}.login-tab-btn{color:var(--color-stone-400);cursor:pointer;border-radius:var(--radius-md);background:0 0;border:none;flex:1;padding:9px;font-family:inherit;font-size:13px;font-weight:600;transition:all .15s}.login-tab-btn.active{background:var(--color-surface);color:var(--color-forest-700);box-shadow:var(--shadow-sm)}#loginPanelOff .field-label,#loginPanelAdm .field-label{margin-bottom:6px}#loginPanelOff select{margin-bottom:1.25rem}#loginPanelOff .pin-dots,#loginPanelAdm .pin-dots{margin-bottom:12px}#profileNameSection .field-label{margin-bottom:6px}#profileNameInput{width:100%;margin-bottom:1rem;display:block}.profile-pin-row{padding:12px 0}.sub-tabs{border-bottom:1px solid var(--color-border);margin-bottom:1rem;display:flex}.sub-tab{color:var(--color-stone-400);cursor:pointer;background:0 0;border:none;border-bottom:2px solid #0000;margin-bottom:-1px;padding:8px 16px;font-family:inherit;font-size:13px;font-weight:500;transition:color .12s,border-color .12s}.sub-tab:hover{color:var(--color-stone-600)}.sub-tab.active{color:var(--color-forest-700);border-bottom-color:var(--color-forest-700);font-weight:600}.toast{background:var(--color-stone-900);color:#fff;border-radius:var(--radius-full);z-index:300;opacity:0;pointer-events:none;white-space:nowrap;box-shadow:var(--shadow-lg);padding:9px 18px;font-size:13px;font-weight:500;transition:opacity .2s,transform .2s;position:fixed;bottom:1.5rem;left:50%;transform:translate(-50%)translateY(8px)}.toast.show{opacity:1;transform:translate(-50%)translateY(0)}.spinner{border:2px solid var(--color-stone-200);border-top-color:var(--color-forest-700);vertical-align:middle;border-radius:50%;width:16px;height:16px;animation:.65s linear infinite spin;display:inline-block}@keyframes spin{to{transform:rotate(360deg)}}@media(max-width:640px){.stat-row{grid-template-columns:repeat(2,1fr)}.main{padding:1rem .75rem 3rem}.flag-steps{flex-direction:column;align-items:stretch;gap:3px}.flag-steps .step-arrow{display:none}.sum-grid{grid-template-columns:repeat(3,1fr);gap:6px}.sum-val{font-size:18px}.arrow-slots{gap:5px}.slot-val{font-size:17px}.np-btn{height:46px;font-size:16px}.confirm-bar{flex-direction:column;align-items:stretch}.confirm-bar .btn{justify-content:center;width:100%}}@property --tw-blur{syntax:"*";inherits:false}@property --tw-brightness{syntax:"*";inherits:false}@property --tw-contrast{syntax:"*";inherits:false}@property --tw-grayscale{syntax:"*";inherits:false}@property --tw-hue-rotate{syntax:"*";inherits:false}@property --tw-invert{syntax:"*";inherits:false}@property --tw-opacity{syntax:"*";inherits:false}@property --tw-saturate{syntax:"*";inherits:false}@property --tw-sepia{syntax:"*";inherits:false}@property --tw-drop-shadow{syntax:"*";inherits:false}@property --tw-drop-shadow-color{syntax:"*";inherits:false}@property --tw-drop-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-drop-shadow-size{syntax:"*";inherits:false}
