@font-face{font-family:Sukhumvit Set;src:url(/assets/SukhumvitSet-Thin-BhfoQOWO.ttf)format("truetype");font-weight:100;font-style:normal;font-display:swap}@font-face{font-family:Sukhumvit Set;src:url(/assets/SukhumvitSet-Light-Rmcz6kU_.ttf)format("truetype");font-weight:300;font-style:normal;font-display:swap}@font-face{font-family:Sukhumvit Set;src:url(/assets/SukhumvitSet-Text-CKV9N9z_.ttf)format("truetype");font-weight:400;font-style:normal;font-display:swap}@font-face{font-family:Sukhumvit Set;src:url(/assets/SukhumvitSet-Medium-CbXmyRlO.ttf)format("truetype");font-weight:500;font-style:normal;font-display:swap}@font-face{font-family:Sukhumvit Set;src:url(/assets/SukhumvitSet-SemiBold-Gj49-igU.ttf)format("truetype");font-weight:600;font-style:normal;font-display:swap}@font-face{font-family:Sukhumvit Set;src:url(/assets/SukhumvitSet-Bold-D72kXJo2.ttf)format("truetype");font-weight:700;font-style:normal;font-display:swap}:root{--text:#6b6375;--text-h:#08060d;--bg:#fff;--border:#e5e4e7;--code-bg:#f4f3ec;--accent:#aa3bff;--accent-bg:#aa3bff1a;--accent-border:#aa3bff80;--social-bg:#f4f3ec80;--shadow:#0000001a 0 10px 15px -3px, #0000000d 0 4px 6px -2px;--sans:Sukhumvit Set, system-ui, Segoe UI, Roboto, sans-serif;--heading:Sukhumvit Set, system-ui, Segoe UI, Roboto, sans-serif;--mono:ui-monospace, Consolas, monospace;font:18px/145% var(--sans);letter-spacing:.18px;--lightningcss-light:initial;--lightningcss-dark: ;color-scheme:light;color:var(--text);background:var(--bg);font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}@media (width<=1024px){:root{font-size:16px}}body{touch-action:manipulation;margin:0}#root{text-align:center;border-inline:1px solid var(--border);box-sizing:border-box;touch-action:manipulation;flex-direction:column;width:1126px;max-width:100%;margin:0 auto;display:flex}@media (width<=700px){#root{padding:0 12px}}h1,h2{font-family:var(--heading);color:var(--text-h);font-weight:500}h1{letter-spacing:-1.68px;margin:32px 0;font-size:56px}@media (width<=1024px){h1{margin:20px 0;font-size:36px}}h2{letter-spacing:-.24px;margin:0 0 8px;font-size:24px;line-height:118%}@media (width<=1024px){h2{font-size:20px}}p{margin:0}code,.counter{font-family:var(--mono);color:var(--text-h);border-radius:4px;display:inline-flex}code{background:var(--code-bg);padding:4px 8px;font-size:15px;line-height:135%}.view-switch{gap:8px;max-width:1100px;margin-top:8px;display:inline-flex}.view-switch button{border:1px solid var(--border);background:var(--bg);color:var(--text-h);cursor:pointer;border-radius:999px;padding:8px 14px}.view-switch button.active{background:var(--accent-bg);border-color:var(--accent-border);color:var(--accent)}.calendar{box-sizing:border-box;-webkit-user-select:none;user-select:none;-webkit-touch-callout:none;max-width:1100px;padding:12px 12px 36px}.calendar input,.calendar select,.calendar textarea{-webkit-user-select:text;user-select:text;-webkit-touch-callout:default}.calendar-header{grid-template-columns:minmax(2.75rem,220px) minmax(0,1fr) minmax(2.75rem,220px);align-items:center;gap:16px;margin-bottom:16px;display:grid}.calendar-header h3{text-align:center;min-width:0;color:var(--text-h);margin:0}.calendar-nav{justify-content:space-between;align-items:center;gap:8px;display:flex}.calendar-nav button{border:1px solid var(--border);background:var(--bg);min-width:2.75rem;color:var(--text-h);font-family:var(--sans);cursor:pointer;border-radius:10px;padding:8px 12px;box-shadow:0 4px 10px #0206170f}.calendar-nav button:hover{border-color:var(--accent-border)}.calendar-nav button:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.calendar-nav-prev{justify-content:flex-start}.calendar-nav-next{justify-content:flex-end}.calendar-search{box-sizing:border-box;border:1px solid color-mix(in srgb, var(--accent) 24%, var(--border));width:100%;color:var(--text-h);background-color:color-mix(in srgb, var(--accent) 4%, var(--bg));background-image:linear-gradient(45deg, transparent 50%, var(--accent) 50%), linear-gradient(135deg, var(--accent) 50%, transparent 50%);appearance:none;background-position:calc(100% - 14px) calc(50% - 1px),calc(100% - 9px) calc(50% - 1px);background-repeat:no-repeat;background-size:5px 5px,5px 5px;border-radius:10px;justify-self:end;padding:7px 32px 7px 9px;font-size:.88rem;transition:border-color .2s,box-shadow .2s,background-color .2s;box-shadow:0 3px 8px #0206170f}.calendar-search::placeholder{color:color-mix(in srgb, var(--text) 36%, #fff)}.calendar-search:hover{border-color:color-mix(in srgb, var(--accent) 38%, var(--border));background-color:color-mix(in srgb, var(--accent) 8%, var(--bg))}.calendar-search:focus{outline:none}.calendar-search:focus-visible{border-color:var(--accent);box-shadow:0 0 0 2px color-mix(in srgb, var(--accent) 28%, transparent);outline:none}.calendar-search option{color:var(--text-h);background-color:var(--bg)}.calendar-search option.reflection-option{color:#2f80ed;font-weight:600}.calendar-search option[value=""],.calendar-search.is-placeholder{color:color-mix(in srgb, var(--text) 52%, #fff)}.calendar-search.is-reflection-selected{color:#2f80ed;font-weight:600}.calendar-actions{justify-self:end;align-items:center;gap:8px;width:100%;margin-bottom:16px;display:flex}.calendar-save-image{border:1px solid var(--border);background:var(--bg);color:var(--text-h);cursor:pointer;white-space:nowrap;border-radius:10px;padding:8px 12px;box-shadow:0 4px 10px #0206170f}.calendar-save-image:hover{border-color:var(--accent-border)}.calendar-save-image:disabled{opacity:.7;cursor:not-allowed}.calendar-grid-scroll{padding-bottom:2px;overflow-x:hidden}.week-header{grid-template-columns:repeat(5,1fr);gap:12px;margin-bottom:6px;display:grid}.weekday{text-align:center;color:var(--text-h);background:#00000005;border-radius:8px;padding:8px 10px;font-weight:700}.weeks-grid{flex-direction:column;gap:12px;display:flex}.week-row{grid-template-columns:repeat(5,1fr);gap:12px;display:grid}.day-card{background:var(--bg);border:1px solid var(--border);aspect-ratio:1;-webkit-tap-highlight-color:transparent;touch-action:manipulation;border-radius:10px;flex-direction:column;gap:8px;min-height:0;padding:12px;transition:transform .12s,box-shadow .12s;display:flex;box-shadow:0 6px 18px #1018280a}.day-card.editable-day{cursor:pointer}.day-card.is-editing{border-color:var(--accent-border);box-shadow:0 0 0 2px #6a47ff1f}.day-card:hover{box-shadow:var(--shadow);transform:translateY(-4px)}.day-card.muted{opacity:.45;filter:grayscale(.1);background:0 0}.day-card.match{background:linear-gradient(180deg, #fff3b073, var(--bg));border-color:#facc1540}.day-card.reflection{background:linear-gradient(180deg, #e6f7ff99, var(--bg));border-color:#46aaff26}.day-card.ward-match{background:linear-gradient(180deg, #ffd8b573, var(--bg));border-color:#ffa05026}.day-card.holiday{background:linear-gradient(180deg, #ffe8e8eb, var(--bg));border-color:#d83b3b73}.day-date{text-align:start;color:var(--text-h);align-items:center;font-weight:600;display:flex}.day-top-row{justify-content:space-between;align-items:center;gap:8px;display:flex}.day-badge{gap:8px}.day-number{background:var(--accent-bg);color:var(--accent);border-radius:8px;padding:4px 8px;font-size:18px}.day-weekday{color:var(--text);letter-spacing:.02em;font-size:12px}.day-key{color:var(--text);margin-left:8px;font-size:12px}.person-list{color:var(--text);justify-content:space-between;align-items:center;gap:8px;margin-top:auto;font-size:13px;display:flex}.person-label{color:var(--text);opacity:.8;font-weight:600}.person-inline-label{color:var(--text);opacity:.8;flex-shrink:0;font-weight:600}.person-names{color:var(--text-h);text-align:right;font-weight:500}.reflection-name{color:#2f80ed;font-weight:600}.holiday-name{color:#b42318;font-weight:600}.day-or-names{white-space:nowrap;text-overflow:ellipsis;flex:1;justify-content:flex-end;align-items:center;gap:6px;min-width:0;display:flex;overflow:hidden}.day-edit-row{-webkit-tap-highlight-color:transparent;grid-template-columns:78px 1fr;align-items:center;gap:6px;font-size:12px;display:grid}.day-edit-row label.editable-day:active{background:inherit}.day-edit-row label{color:var(--text);text-align:left}.day-edit-row select{border:1px solid var(--border);background:var(--bg);min-width:0;color:var(--text-h);border-radius:8px;padding:4px 6px}.day-edit-modal{z-index:60;justify-content:center;align-items:center;padding:24px;display:flex;position:fixed;inset:0}.day-edit-modal-backdrop{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#0f172a73;position:absolute;inset:0}.day-edit-panel{border:1px solid var(--border);background:var(--bg);text-align:left;border-radius:18px;flex-direction:column;gap:12px;width:min(100%,440px);padding:20px;display:flex;position:relative;box-shadow:0 24px 70px #0f172a38}.day-edit-panel-header{justify-content:space-between;align-items:flex-start;gap:12px;display:flex}.day-edit-panel-header h3{color:var(--text-h);margin:0}.day-edit-panel-header p{color:var(--text);opacity:.8;margin-top:4px;font-size:14px}.day-edit-close{border:1px solid var(--border);width:36px;height:36px;color:var(--text-h);cursor:pointer;background:0 0;border-radius:999px;font-size:22px;line-height:1}.day-edit-actions{justify-content:flex-end;gap:6px;margin-top:4px;display:flex}.day-edit-toggle{color:var(--text);align-items:center;gap:8px;margin-top:4px;font-size:12px;display:inline-flex}.day-edit-toggle input{accent-color:#d83b3b;width:14px;height:14px}.day-edit-actions button,.day-edit-wrap>button{border:1px solid var(--border);background:var(--bg);color:var(--text-h);cursor:pointer;border-radius:8px;padding:5px 8px}.day-edit-actions button:hover,.day-edit-wrap>button:hover{border-color:var(--accent-border)}.calendar-month-summary{text-align:left;margin-top:24px}.calendar-month-summary h3{color:var(--text-h);margin:0 0 10px}.summary-page{box-sizing:border-box;max-width:1100px;margin:16px auto;padding:12px}.summary-total-cards{grid-template-columns:repeat(3,minmax(0,1fr));gap:8px;display:grid}.summary-total-card{border:1px solid var(--border);background:var(--bg);text-align:center;border-radius:10px;padding:8px 10px}.summary-total-label{color:var(--text);font-size:12px}.summary-total-value{color:var(--text-h);font-size:20px;font-weight:700;line-height:1.2}.summary-section{text-align:left}.summary-section .summary-header{justify-content:space-between;align-items:center;gap:12px;margin-bottom:16px;display:flex}.summary-section .summary-header h3{text-align:center;color:var(--text-h);flex:1;margin:0}.summary-section .summary-header .calendar-nav{flex:none}.summary-section h2{text-align:center;color:var(--text-h);margin:0 0 16px}.summary-section h3{color:var(--text-h);margin:0 0 10px}.summary-table-wrap{border:1px solid var(--border);background:var(--bg);border-radius:10px;overflow-x:auto}.summary-table{border-collapse:collapse;width:100%;min-width:900px}.summary-table th,.summary-table td{border-bottom:1px solid var(--border);vertical-align:top;padding:10px 12px;font-size:14px}.summary-table th{background:var(--bg);color:var(--text-h);text-align:left;font-weight:700;position:sticky;top:0}.summary-table tbody tr:hover{background:#00000005}.summary-table tbody tr:last-child td{border-bottom:none}.month-setup-groups{flex-wrap:wrap;justify-content:center;align-items:start;gap:12px;margin-top:8px;display:flex}.month-setup-group-card{border:1px solid color-mix(in srgb, var(--accent) 18%, var(--border));box-sizing:border-box;background:linear-gradient(165deg, color-mix(in srgb, var(--accent) 5%, var(--bg)) 0%, var(--bg) 65%);border-radius:14px;flex-direction:column;gap:10px;width:100%;min-width:0;max-width:400px;padding:14px;display:flex;box-shadow:inset 0 1px #fffc,0 10px 24px #0000000f}.month-setup-group-title{color:var(--text-h);margin:0;font-size:1.02rem;font-weight:700}.month-setup-add-btn{border:1px solid var(--accent);background:color-mix(in srgb, var(--accent) 12%, var(--bg));color:var(--text-h);cursor:pointer;border-radius:10px;align-self:start;padding:8px 12px;font-weight:600;transition:background-color .2s,transform .12s,box-shadow .2s}.month-setup-add-btn:hover{background:color-mix(in srgb, var(--accent) 18%, var(--bg));box-shadow:0 4px 10px #aa3bff29}.month-setup-add-btn:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.month-setup-add-btn:active{transform:translateY(1px)}.month-setup-people-list{gap:8px;margin-top:8px;display:grid}.month-setup-person-row{flex-wrap:nowrap;align-items:center;gap:6px;min-width:0;display:flex}.month-setup-person-row>*{min-width:0}.month-setup-person-row>:first-child{flex:auto}.month-setup-person-row button{white-space:nowrap}.month-setup-person-select{border:1px solid color-mix(in srgb, var(--accent) 24%, var(--border));color:var(--text-h);background-color:color-mix(in srgb, var(--accent) 4%, var(--bg));background-image:linear-gradient(45deg, transparent 50%, var(--accent) 50%), linear-gradient(135deg, var(--accent) 50%, transparent 50%);appearance:none;background-position:calc(100% - 14px) calc(50% - 1px),calc(100% - 9px) calc(50% - 1px);background-repeat:no-repeat;background-size:5px 5px,5px 5px;border-radius:10px;flex:auto;padding:7px 32px 7px 9px;font-size:.88rem;transition:border-color .2s,box-shadow .2s,background-color .2s;box-shadow:0 3px 8px #0206170f}.month-setup-person-select:hover{border-color:color-mix(in srgb, var(--accent) 38%, var(--border));background-color:color-mix(in srgb, var(--accent) 8%, var(--bg))}.month-setup-person-select:focus-visible{border-color:var(--accent);box-shadow:0 0 0 2px color-mix(in srgb, var(--accent) 28%, transparent);outline:none}.month-setup-reflection-label{white-space:nowrap;color:color-mix(in srgb, var(--text) 88%, var(--text-h));flex-shrink:0;align-items:center;gap:4px;font-size:.75rem;font-weight:500;display:inline-flex}.month-setup-reflection-label input{width:14px;height:14px;accent-color:var(--accent)}.month-setup-remove-btn{border:1px solid color-mix(in srgb, #d83b3b 52%, var(--border));white-space:nowrap;min-height:30px;font:inherit;background:color-mix(in srgb, #d83b3b 10%, var(--bg));color:color-mix(in srgb, #d83b3b 88%, var(--text-h));cursor:pointer;border-radius:9px;padding:4px 9px;font-size:.82rem;font-weight:600;transition:transform .12s,box-shadow .2s,border-color .2s,background-color .2s}.month-setup-remove-btn:hover{border-color:color-mix(in srgb, #d83b3b 62%, var(--border));background:color-mix(in srgb, #d83b3b 15%, var(--bg));box-shadow:0 4px 10px #d83b3b29}.month-setup-remove-btn:focus-visible{outline-offset:2px;outline:2px solid #d83b3b}.month-setup-remove-btn:active{transform:translateY(1px)}.month-setup-remove-btn:disabled{opacity:.7;cursor:not-allowed;box-shadow:none;transform:none}.month-setup-toggle-bar{border:1px solid var(--border);background:linear-gradient(180deg, #ffffffb3 0%, #f4f3ec80 100%), var(--bg);border-radius:999px;justify-content:center;align-items:center;gap:6px;padding:6px;display:inline-flex}.month-setup-toggle-btn{color:var(--text-h);cursor:pointer;background:0 0;border:1px solid #0000;border-radius:999px;min-height:40px;padding:10px 14px;font-weight:600;line-height:1;transition:background-color .2s,color .2s,border-color .2s,transform .12s}.month-setup-toggle-btn:hover{background:#aa3bff14;border-color:#aa3bff33}.month-setup-toggle-btn:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.month-setup-toggle-btn:active{transform:translateY(1px)}.month-setup-toggle-btn.is-active{background:var(--accent);color:#fff;border-color:var(--accent);box-shadow:0 4px 12px #aa3bff47}.month-setup-generate-wrap{justify-content:center;margin-top:12px;margin-bottom:24px;display:flex}.month-setup-generate-btn{border:1px solid var(--accent);letter-spacing:.01em;color:#fff;background:linear-gradient(135deg, color-mix(in srgb, var(--accent) 85%, #fff) 0%, var(--accent) 65%);cursor:pointer;border-radius:12px;min-height:42px;padding:10px 18px;font-weight:700;transition:transform .12s,box-shadow .2s,filter .2s}.month-setup-generate-btn:hover{filter:brightness(1.04);box-shadow:0 10px 22px #aa3bff57}.month-setup-generate-btn:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.month-setup-generate-btn:active{transform:translateY(1px)}.month-setup-person-panel{border-color:color-mix(in srgb, var(--accent) 22%, var(--border));gap:10px;max-width:520px;margin:10px auto 0;padding:14px;font-size:.92rem;box-shadow:inset 0 1px #fffc,0 10px 22px #120c2314}.month-setup-person-panel .month-setup-group-title{font-size:.95rem}.month-setup-person-add-row{gap:8px;display:flex}.month-setup-person-input{box-sizing:border-box;border:1px solid color-mix(in srgb, var(--accent) 24%, var(--border));width:100%;min-width:0;font:inherit;color:var(--text-h);background:color-mix(in srgb, var(--accent) 4%, var(--bg));border-radius:9px;padding:7px 10px;font-size:.88rem;transition:border-color .2s,box-shadow .2s,background-color .2s;box-shadow:0 2px 6px #0206170d}.month-setup-person-input::placeholder{color:color-mix(in srgb, var(--text) 84%, var(--text-h))}.month-setup-person-input:hover{border-color:color-mix(in srgb, var(--accent) 38%, var(--border));background:color-mix(in srgb, var(--accent) 7%, var(--bg))}.month-setup-person-input:focus-visible{border-color:var(--accent);box-shadow:0 0 0 2px color-mix(in srgb, var(--accent) 28%, transparent);background:color-mix(in srgb, var(--accent) 9%, var(--bg));outline:none}.month-setup-person-btn{border:1px solid color-mix(in srgb, var(--accent) 24%, var(--border));white-space:nowrap;min-height:30px;font:inherit;color:var(--text-h);background:var(--bg);cursor:pointer;border-radius:9px;padding:4px 9px;font-size:.82rem;font-weight:600;transition:transform .12s,box-shadow .2s,border-color .2s,background-color .2s}.month-setup-person-btn:hover{border-color:color-mix(in srgb, var(--accent) 38%, var(--border));box-shadow:0 4px 10px #02061714}.month-setup-person-btn:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.month-setup-person-btn:active{transform:translateY(1px)}.month-setup-person-btn:disabled{opacity:.7;cursor:not-allowed;box-shadow:none;transform:none}.month-setup-person-btn-primary{border-color:var(--accent);color:#fff;background:linear-gradient(135deg, color-mix(in srgb, var(--accent) 80%, #fff) 0%, var(--accent) 70%);box-shadow:0 5px 12px #aa3bff38}.month-setup-person-btn-primary:hover{border-color:var(--accent);filter:brightness(1.03);box-shadow:0 7px 16px #aa3bff42}.month-setup-person-btn-subtle{background:color-mix(in srgb, var(--accent) 10%, var(--bg))}.month-setup-person-btn-danger{border-color:color-mix(in srgb, #d83b3b 52%, var(--border));color:color-mix(in srgb, #d83b3b 88%, var(--text-h));background:color-mix(in srgb, #d83b3b 10%, var(--bg))}.month-setup-person-btn-danger:hover{border-color:color-mix(in srgb, #d83b3b 62%, var(--border));background:color-mix(in srgb, #d83b3b 15%, var(--bg));box-shadow:0 4px 10px #d83b3b29}.month-setup-person-btn-danger:focus-visible{outline-color:#d83b3b}.month-setup-person-panel .month-setup-people-list{gap:8px}.month-setup-person-panel .month-setup-person-row{border:1px solid color-mix(in srgb, var(--accent) 12%, var(--border));background:color-mix(in srgb, var(--accent) 3%, var(--bg));border-radius:9px;gap:8px;padding:6px}.month-setup-person-name{text-align:left;min-width:0;color:var(--text-h);flex:auto;padding-right:12px;font-size:.9rem;font-weight:500}@media (width<=900px){.view-switch{box-sizing:border-box;grid-template-columns:1fr 1fr;width:100%;display:grid}.view-switch button{width:100%}.calendar,.summary-page{padding:10px 8px}.summary-section .summary-header{gap:8px}.summary-section .summary-header h2{font-size:clamp(1rem,4vw,1.25rem)}.summary-section .summary-header .calendar-nav{flex:none}.summary-section .summary-header .calendar-nav button{width:auto;min-width:2.5rem;padding:8px 10px}.calendar-header{grid-template-columns:minmax(2.5rem,auto) minmax(0,1fr) minmax(2.5rem,auto);gap:8px}.calendar-header h3{font-size:clamp(1rem,4vw,1.25rem)}.calendar-nav{justify-content:center}.calendar-nav button{width:100%;min-width:0;padding:8px 10px}.calendar-search{justify-self:stretch;width:100%;min-width:0}.calendar-actions{justify-self:stretch}.calendar-save-image{flex-shrink:0}.summary-total-cards{width:100%}.week-header,.week-row{gap:8px}.day-card{padding:10px}.day-number{font-size:16px}.person-list{font-size:12px}}@media (width<=700px){.calendar{padding:8px 4px 36px}.summary-page{padding:8px 4px}.week-header{gap:4px;margin-bottom:4px}.month-setup-person-row{flex-wrap:wrap}.month-setup-toggle-bar{box-sizing:border-box;border-radius:14px;grid-template-columns:1fr;width:100%;display:grid}.month-setup-toggle-btn{border-radius:10px;width:100%}.month-setup-add-btn,.month-setup-generate-btn{justify-content:center;width:100%}.month-setup-person-panel .month-setup-person-add-row{flex-direction:column}.month-setup-person-panel .month-setup-person-row{gap:8px}.weekday{padding:5px 6px;font-size:10px}.weeks-grid{gap:6px}.week-row{gap:4px}.calendar-grid-scroll{-webkit-overflow-scrolling:touch;overflow-x:auto}.day-card{border-radius:8px;gap:4px;padding:6px 5px}.day-edit-modal{padding:12px}.day-edit-panel{border-radius:14px;width:min(100%,360px);padding:16px}.day-edit-panel-header p{font-size:12px}.day-date{display:block}.day-top-row{gap:6px}.day-badge{gap:4px}.day-number{border-radius:6px;padding:2px 6px;font-size:12px}.day-weekday,.day-key{display:none}.person-list{font-size:10px;line-height:1.2;display:block}.person-list+.person-list{margin-top:2px}.person-label{display:none}.person-inline-label{display:inline}.person-names{text-align:left;white-space:nowrap;text-overflow:ellipsis;font-size:10px;display:block;overflow:hidden}.day-or-names{text-align:right;justify-content:flex-end;display:flex}.day-edit-row{grid-template-columns:1fr;gap:3px;font-size:10px}.day-edit-row select,.day-edit-actions button,.day-edit-wrap>button{padding:4px 5px;font-size:10px}.calendar-actions{grid-template-columns:1fr;gap:6px;display:grid}.calendar-save-image{justify-self:stretch;width:100%}.summary-table{table-layout:fixed;min-width:0}.summary-table th,.summary-table td{word-break:break-word;padding:8px 6px;font-size:11px}.summary-total-value{font-size:17px}}.counter{color:var(--accent);background:var(--accent-bg);border:2px solid #0000;border-radius:5px;margin-bottom:24px;padding:5px 10px;font-size:16px;transition:border-color .3s}.counter:hover{border-color:var(--accent-border)}.counter:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.hero{position:relative}.hero .base,.hero .framework,.hero .vite{margin:0 auto;inset-inline:0}.hero .base{z-index:0;width:170px;position:relative}.hero .framework,.hero .vite{position:absolute}.hero .framework{z-index:1;height:28px;top:34px;transform:perspective(2000px)rotate(300deg)rotateX(44deg)rotateY(39deg)scale(1.4)}.hero .vite{z-index:0;width:auto;height:26px;top:107px;transform:perspective(2000px)rotate(300deg)rotateX(40deg)rotateY(39deg)scale(.8)}#center{flex-direction:column;flex-grow:1;place-content:center;place-items:center;gap:25px;display:flex}@media (width<=1024px){#center{gap:18px;padding:32px 20px 24px}}#next-steps{border-top:1px solid var(--border);text-align:left;display:flex}#next-steps>div{flex:1 1 0;padding:32px}@media (width<=1024px){#next-steps>div{padding:24px 20px}}#next-steps .icon{width:22px;height:22px;margin-bottom:16px}@media (width<=1024px){#next-steps{text-align:center;flex-direction:column}}#docs{border-right:1px solid var(--border)}@media (width<=1024px){#docs{border-right:none;border-bottom:1px solid var(--border)}}#next-steps ul{gap:8px;margin:32px 0 0;padding:0;list-style:none;display:flex}#next-steps ul .logo{height:18px}#next-steps ul a{color:var(--text-h);background:var(--social-bg);border-radius:6px;align-items:center;gap:8px;padding:6px 12px;font-size:16px;text-decoration:none;transition:box-shadow .3s;display:flex}#next-steps ul a:hover{box-shadow:var(--shadow)}#next-steps ul a .button-icon{width:18px;height:18px}@media (width<=1024px){#next-steps ul{flex-wrap:wrap;justify-content:center;margin-top:20px}#next-steps ul li{flex:calc(50% - 8px)}#next-steps ul a{box-sizing:border-box;justify-content:center;width:100%}}#spacer{border-top:1px solid var(--border);height:88px}@media (width<=1024px){#spacer{height:48px}}.ticks{width:100%;position:relative}.ticks:before,.ticks:after{content:"";border:5px solid #0000;position:absolute;top:-4.5px}.ticks:before{border-left-color:var(--border);left:0}.ticks:after{border-right-color:var(--border);right:0}.auth-panel{text-align:right;border:1px solid var(--border);background:color-mix(in srgb, var(--accent-bg) 35%, var(--bg));border-radius:14px}.auth-panel-discreet{text-align:right;background:0 0;border:none}.auth-row{flex-wrap:wrap;justify-content:center;align-items:center;gap:10px;display:flex}.auth-badge{border:1px solid var(--accent-border);color:var(--text-h);background:var(--bg);border-radius:999px;align-items:center;padding:6px 12px;font-size:14px;line-height:1.2;display:inline-flex}.auth-button{-webkit-tap-highlight-color:transparent;appearance:none;font:inherit;cursor:pointer;-webkit-user-select:none;user-select:none;border:1px solid #0000;border-radius:999px;padding:8px 16px;font-weight:600;line-height:1.2;transition:transform .15s,box-shadow .2s,border-color .2s,background-color .2s}.auth-button:disabled{opacity:.65;cursor:not-allowed;box-shadow:none;transform:none}.auth-button:not(:disabled):hover{transform:translateY(-1px);box-shadow:0 8px 18px #02061724}.auth-button:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.auth-button-primary{background:linear-gradient(135deg, var(--accent), color-mix(in srgb, var(--accent) 75%, #fff));color:#fff;border-color:color-mix(in srgb, var(--accent) 70%, #000)}.auth-button-danger{background:color-mix(in srgb, #ef4444 12%, var(--bg));color:color-mix(in srgb, #7f1d1d 70%, var(--text-h));border-color:color-mix(in srgb, #ef4444 45%, var(--border))}.auth-button-danger:not(:disabled):hover{background:color-mix(in srgb, #ef4444 18%, var(--bg))}.auth-entry-button{-webkit-tap-highlight-color:transparent;appearance:none;color:color-mix(in srgb, var(--text) 85%, #000);font:inherit;letter-spacing:.2px;cursor:pointer;background:0 0;border:1px solid #0000;border-radius:999px;padding:4px 8px;font-size:13px;transition:color .2s,background-color .2s}.auth-entry-button:hover{color:var(--text-h);background:color-mix(in srgb, var(--social-bg) 60%, transparent)}.auth-entry-button:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.auth-hide-button{-webkit-tap-highlight-color:transparent;appearance:none;color:var(--text);font:inherit;cursor:pointer;background:0 0;border:1px solid #0000;border-radius:999px;padding:6px 10px;font-size:14px;transition:background-color .2s,color .2s}.auth-hide-button:not(:disabled):hover{color:var(--text-h);background:color-mix(in srgb, var(--social-bg) 70%, transparent)}.auth-hide-button:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.view-switch button{-webkit-tap-highlight-color:transparent;-webkit-user-select:none;user-select:none}.view-switch button:active{background-color:#0000}
