.home-page{max-width:1040px;gap:.75rem}.home-hero{position:relative;padding:1rem;border-color:#c9d8ef;box-shadow:0 22px 46px #19346221}.home-hero__body{display:grid;gap:1rem;text-align:center}.home-hero h1{margin:0;font-size:clamp(2.05rem,8.7vw,2.9rem);line-height:1.04;letter-spacing:-.03em}.hero-title-accent{color:#2b5fbf}@supports ((-webkit-background-clip: text) or (background-clip: text)){.hero-title-accent{background:linear-gradient(90deg,#2b5fbf,#4d82df 58%,#7caeff);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;color:transparent}}.hero-standfirst{margin:0;color:#3c5a8d;font-size:1.02rem;line-height:1.55;font-weight:500}.message-highlights{display:flex;justify-content:center;flex-wrap:wrap;gap:.5rem}.message-pill{display:inline-flex;align-items:center;min-height:2rem;padding:.45rem .8rem;border:1px solid #c8d7ef;border-radius:999px;background:linear-gradient(180deg,#f6f9ff,#eaf2ff);color:#2f4f88;font-size:.92rem;font-weight:700}.campaign-message{display:grid;gap:.95rem}.campaign-message p{margin:0;color:#516482;font-size:1.02rem;line-height:1.62}.home-actions-grid{display:grid;grid-template-columns:1fr;gap:.75rem}.home-action-card{border:1px solid #c8d8ef;border-radius:14px;padding:.95rem;display:flex;flex-direction:column;gap:.7rem}.home-action-card h3{margin:0;color:#244f90;text-align:center;font-size:1.9rem}.home-action-card p{margin:0;color:#4f6487;text-align:center;font-size:1.02rem;line-height:1.5;flex:1}.home-action-card .btn{width:100%;height:3rem;min-height:3rem;padding:0 1rem;margin-top:auto;display:flex;align-items:center;justify-content:center;text-align:center;white-space:nowrap;line-height:1;font-family:Poppins,sans-serif;font-size:1.02rem;font-weight:700;color:#1f4389;border:1px solid #b8cdef;background:linear-gradient(180deg,#dcebff,#bdd6ff);box-shadow:0 8px 18px #345fb033}.home-action-card .btn:hover{box-shadow:0 12px 26px #345fb047}.sign-modal{position:fixed;top:0;right:0;bottom:0;left:0;z-index:60;display:grid;place-items:center;padding:1rem}.sign-modal[hidden]{display:none}.sign-modal__backdrop{position:absolute;top:0;right:0;bottom:0;left:0;background:#131f347a}.sign-modal__dialog{position:relative;width:min(560px,100%);border-radius:18px;border:1px solid #bfd0ea;background:linear-gradient(180deg,#f8fbff,#edf4ff);box-shadow:0 30px 60px #14274952;padding:1rem}.sign-modal__close{position:absolute;top:.5rem;right:.5rem;width:2rem;height:2rem;border:0;border-radius:999px;font-size:1.3rem;line-height:1;color:#2b4d86;background:transparent;cursor:pointer}.sign-modal__intro{margin:0 0 .8rem;color:#4f6487}.sign-modal__form{display:grid;grid-template-columns:1fr;gap:.7rem}.sign-field{display:grid;gap:.35rem}.sign-field input{width:100%}.sign-modal__actions{display:flex;gap:.6rem;justify-content:space-between;align-items:center;grid-column:1 / -1}.sign-modal .btn{display:inline-flex;align-items:center;justify-content:center;gap:.45rem;white-space:nowrap}.btn-icon-text{display:inline-flex;align-items:center;justify-content:center;font-size:1rem;line-height:1}.sign-modal__status{min-height:1.2rem;font-weight:600;color:#2a4d84;grid-column:1 / -1}@media (min-width: 641px){.home-hero{padding:1.35rem}.home-hero__body{text-align:left}.message-highlights{justify-content:flex-start}.home-actions-grid,.sign-modal__form{grid-template-columns:repeat(2,minmax(0,1fr))}.sign-field--full{grid-column:1 / -1}}@media (min-width: 961px){.home-hero{padding:1.65rem}.home-hero h1{font-size:clamp(2.4rem,5.2vw,4rem)}.home-actions-grid{grid-template-columns:repeat(3,minmax(0,1fr))}}.about-story-copy{display:grid;gap:1rem;margin-top:1.35rem}.about-story-copy p{color:#4f6382;font-size:.98rem;line-height:1.7}@supports ((-webkit-background-clip: text) or (background-clip: text)){.page-shell h1{background:linear-gradient(90deg,#2b5fbf,#4d82df 58%,#7caeff);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;color:transparent}}.page-note{margin-top:1rem;padding:.75rem .85rem;border:1px dashed #b9cbea;border-radius:var(--radius-sm);background:#f4f8ff;color:#375281}.page-shell h1{margin-top:.15rem;font-size:clamp(2.45rem,5.2vw,4.05rem);line-height:1.08;letter-spacing:-.03em;color:#2b5fbf;padding-bottom:.06em}.priorities-grid-shell h2{margin-bottom:.85rem;font-size:clamp(1.5rem,2.4vw,2rem);line-height:1.1;letter-spacing:-.02em;color:#2b5fbf;display:inline-flex;align-items:center;gap:.5rem}.section-head{display:flex;align-items:center;justify-content:space-between;gap:.75rem}.section-head h2{margin-bottom:0}.reaction-btn{border:1px solid #c1d4f0;border-radius:999px;background:#f4f8ff;color:#234ea0;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;gap:.42rem;font:inherit;font-size:.82rem;font-weight:600;min-height:2.6rem;width:100%;padding:.5rem .9rem;transition:background-color .16s ease,border-color .16s ease,color .16s ease,transform .16s ease,box-shadow .16s ease}.reaction-btn:hover{transform:translateY(-1px);border-color:#92b0df;background:#eaf2ff}.reaction-btn:focus-visible{outline:2px solid #7fa7e4;outline-offset:2px}.reaction-btn[aria-pressed=true]{background:linear-gradient(180deg,#2b5fbf,#234ea0);border-color:#234ea0;color:#fff;box-shadow:0 10px 22px #234ea03d}.reaction-btn-row{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:.65rem}.reaction-icon{line-height:1;width:1rem;height:1rem;display:inline-flex;align-items:center;justify-content:center}.reaction-icon svg{width:1rem;height:1rem;display:block;fill:none;stroke:currentColor;stroke-width:1.8;stroke-linecap:round;stroke-linejoin:round}.reaction-btn[aria-pressed=true] .reaction-icon svg{fill:currentColor}.reaction-status{font-size:.8rem;color:#5a6c8f;min-height:1.2em}.priority-box{display:flex;flex-direction:column}.priority-box p{flex:1 1 auto}.card-reactions{margin-top:.95rem;padding-top:.85rem;border-top:1px solid rgba(43,95,191,.12);display:grid;gap:.55rem}.feedback-cta{border:1px solid #c1d4f0;border-radius:999px;background:#f4f8ff;color:#234ea0;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;font:inherit;font-size:.82rem;font-weight:600;min-height:2.6rem;padding:.5rem .9rem;width:100%;transition:background-color .16s ease,border-color .16s ease,color .16s ease,transform .16s ease,box-shadow .16s ease}.feedback-cta:hover{transform:translateY(-1px);border-color:#92b0df;background:#eaf2ff}.feedback-cta:focus-visible{outline:2px solid #7fa7e4;outline-offset:2px}.feedback-cta[hidden]{display:none}.feedback-panel h2{margin-bottom:.75rem}.feedback-panel .lead{margin-top:0}.feedback-panel-actions{margin-top:1rem}.feedback-modal{position:fixed;top:0;right:0;bottom:0;left:0;z-index:200;display:grid;place-items:center;padding:1.25rem}.feedback-modal[hidden]{display:none}.feedback-modal__backdrop{position:absolute;top:0;right:0;bottom:0;left:0;background:#101c338f;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px)}.feedback-modal__dialog{position:relative;z-index:1;width:min(100%,42rem);max-height:min(90vh,52rem);overflow:auto;border:1px solid rgba(151,178,224,.9);border-radius:24px;background:linear-gradient(180deg,#fffffffa,#f5f9fffa);box-shadow:0 28px 65px #0f214347;padding:1.35rem}.feedback-modal__close{position:absolute;top:.9rem;right:.9rem;border:0;background:transparent;color:#315792;cursor:pointer;font-size:1.7rem;line-height:1;padding:.2rem .45rem}.feedback-modal__close:hover{color:#173a77}.feedback-modal__close:focus-visible{outline:2px solid #7fa7e4;outline-offset:2px}.feedback-modal__eyebrow{display:inline-block;margin-bottom:.5rem}.feedback-modal__title{margin-bottom:.35rem;color:#2b5fbf}.feedback-modal__summary{margin-bottom:1rem}.feedback-modal__context{margin-bottom:1rem;border:1px solid #c7d8f2;border-radius:var(--radius-md);background:#f4f8ff;padding:.9rem 1rem;color:#35517f;font-size:.92rem}.feedback-modal__grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:.85rem}.feedback-modal__grid>label:last-child{grid-column:1 / -1}.feedback-modal__contact-fields{display:contents}.feedback-modal__contact-fields[hidden]{display:none}.feedback-modal__anonymous{grid-column:1 / -1;display:flex;align-items:center;justify-content:space-between;gap:.9rem;padding:.8rem .95rem;border:1px solid #c7d8f2;border-radius:var(--radius-md);background:#f4f8ff;color:#35517f}.feedback-modal__anonymous-copy{display:grid;gap:.12rem}.feedback-modal__anonymous-copy strong{color:#214786;font-size:.92rem}.feedback-modal__anonymous-copy span{font-size:.8rem}.feedback-modal__switch{position:relative;display:inline-flex;align-items:center;flex:0 0 auto}.feedback-modal__switch input{position:absolute;opacity:0;pointer-events:none}.feedback-modal__switch-track{width:3.2rem;height:1.85rem;border-radius:999px;background:#c6d7f1;box-shadow:inset 0 0 0 1px #2548881a;transition:background-color .16s ease}.feedback-modal__switch-track:after{content:"";position:absolute;top:.18rem;left:.18rem;width:1.5rem;height:1.5rem;border-radius:50%;background:#fff;box-shadow:0 2px 8px #182c542e;transition:transform .16s ease}.feedback-modal__switch input:checked+.feedback-modal__switch-track{background:linear-gradient(180deg,#2b5fbf,#234ea0)}.feedback-modal__switch input:checked+.feedback-modal__switch-track:after{transform:translate(1.35rem)}.feedback-modal__switch input:focus-visible+.feedback-modal__switch-track{outline:2px solid #7fa7e4;outline-offset:2px}.feedback-modal__actions{display:flex;flex-wrap:wrap;justify-content:flex-end;gap:.7rem;margin-top:1rem}.feedback-modal__status{margin-top:.8rem;min-height:1.2em;color:#4e6387;font-size:.86rem}body.feedback-modal-open{overflow:hidden}.section-toggle-btn{border:0;background:transparent;color:#234ea0;cursor:pointer;padding:.08rem;line-height:1;display:inline-flex;align-items:center;justify-content:center}.section-toggle-btn:hover{color:#173a77}.section-toggle-btn:focus-visible{outline:2px solid #7fa7e4;outline-offset:2px}.section-toggle-icon{display:inline-flex;align-items:center;justify-content:center}.section-toggle-icon svg{width:1.15rem;height:1.15rem;display:block}.section-toggle-icon .icon-down,.section-toggle-btn[aria-expanded=false] .icon-up{display:none}.section-toggle-btn[aria-expanded=false] .icon-down{display:block}.priorities-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:.8rem;margin-top:.85rem}.priorities-grid[hidden]{display:none}.priority-box{border:1px solid #c9d9f0;border-radius:12px;padding:.85rem;background:linear-gradient(180deg,#f8fbff,#edf4ff)}.priority-box h3{margin-bottom:.5rem;font-size:clamp(1.15rem,1.8vw,1.55rem);line-height:1.03;letter-spacing:-.02em;color:#2b5fbf;font-weight:700;display:block}.priority-box p{color:#4f6382;font-size:.92rem}.financial-grid-shell{margin-top:.2rem}.financial-grid-shell .priorities-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.financial-box{background:linear-gradient(180deg,#f5f9ff,#e8f0ff)}.priorities-grid-shell h2:before{content:"";width:1em;height:1em;background-size:contain;background-repeat:no-repeat;background-position:center;flex:0 0 1em}.priorities-grid-shell h2:before{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath fill='%232b5fbf' d='M4 4h16v16H4z'/%3E%3Cpath fill='%23ffffff' d='M7 8h10v2H7zm0 4h10v2H7zm0 4h7v2H7z'/%3E%3C/svg%3E")}.financial-grid-shell h2:before{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Ccircle cx='12' cy='12' r='10' fill='%232b5fbf'/%3E%3Cpath fill='%23ffffff' d='M13 5h-2v2.1c-2 .3-3.3 1.7-3.3 3.5 0 2 1.6 2.9 3.8 3.5 1.8.5 2.6.9 2.6 1.9 0 .9-.8 1.5-2.2 1.5-1.4 0-2.5-.5-3.4-1.3l-1.4 1.6c1 .9 2.2 1.5 3.9 1.7V21h2v-2.1c2.2-.3 3.5-1.7 3.5-3.5 0-2.2-1.5-3.1-4-3.8-1.7-.4-2.3-.9-2.3-1.7 0-.8.7-1.4 2-1.4 1.1 0 2 .4 2.8 1.1l1.3-1.6c-.9-.8-1.9-1.3-3.3-1.5z'/%3E%3C/svg%3E")}@supports ((-webkit-background-clip: text) or (background-clip: text)){.page-shell h1,.priorities-grid-shell h2,.priority-box h3{background:linear-gradient(90deg,#2b5fbf,#4d82df 58%,#7caeff);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;color:transparent}}@media (max-width: 980px){.priorities-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}@media (max-width: 640px){.section-head{flex-direction:column;align-items:stretch}.reaction-btn-row{grid-template-columns:1fr}.reaction-btn,.feedback-cta{min-height:2.7rem}.feedback-modal{padding:.8rem}.feedback-modal__dialog{padding:1rem}.feedback-modal__grid{grid-template-columns:1fr}.feedback-modal__anonymous{align-items:flex-start}.priorities-grid,.financial-grid-shell .priorities-grid{grid-template-columns:1fr}}.page-shell{position:relative}.contact-details{display:grid;gap:.85rem;margin-top:1.4rem}.contact-link{display:flex;align-items:center;gap:.85rem;padding:.9rem 1rem;border:1px solid #d8e2f3;border-radius:var(--radius-sm);background:#f7faff;color:#1e3358;text-decoration:none;transition:border-color .16s ease,box-shadow .16s ease,transform .16s ease}.contact-link:hover,.contact-link:focus-visible{border-color:#7fa4d8;box-shadow:0 10px 24px #254b7d21;transform:translateY(-1px)}.contact-icon{display:inline-grid;flex:0 0 auto;place-items:center;width:2.4rem;height:2.4rem;border-radius:50%;background:#244d85;color:#fff}.contact-icon svg{width:1.25rem;height:1.25rem}.contact-label,.contact-value{display:block}.contact-label{font-size:.8rem;font-weight:700;text-transform:uppercase;color:#5f7599}.contact-value{overflow-wrap:anywhere;font-size:1rem;font-weight:600;color:#1e3358}@media (max-width: 520px){.contact-link{align-items:flex-start}}.page-shell{position:relative;z-index:1}.game-wrap{margin-top:1rem;display:grid;gap:.9rem;background:linear-gradient(180deg,#f7fbff,#ecf4ff);border:1px solid #c8d9f2;border-radius:16px;padding:.9rem}.game-mount-shell{position:relative}.game-mount{width:100%;max-width:var(--game-render-width, 900px);aspect-ratio:var(--game-aspect-ratio, 900 / 520);margin-inline:auto;border:1px solid #9db9df;border-radius:16px;overflow:hidden;background:linear-gradient(180deg,#dfeeff,#cfdff4);box-shadow:inset 0 0 0 1px #ffffff73,0 10px 24px #1f3e702e;contain:layout paint;touch-action:manipulation}.game-mount canvas{display:block;width:100%!important;height:100%!important;touch-action:none}.game-overlay-actions{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;padding:1rem;pointer-events:none}.game-overlay-actions[hidden]{display:none}.game-result-popup{width:min(100%,22rem);display:grid;gap:.75rem;justify-items:center;padding:1.1rem;border:1px solid rgba(196,216,244,.7);border-radius:16px;background:#f7fbfff0;box-shadow:0 18px 36px #0c163052;text-align:center;pointer-events:auto}.game-result-title{margin:0;color:#10244a;font-size:clamp(1.35rem,4vw,1.8rem);line-height:1.12;font-weight:800}.game-result-score{margin:0;color:#355380;font-size:1rem;font-weight:700}.high-score-form{width:100%;display:grid;gap:.65rem}.high-score-form label{width:100%;text-align:left;color:#24406f;font-size:.9rem}.high-score-form input{min-height:2.75rem;background:#fff}.high-score-form .btn{width:100%}.high-score-status{min-height:1.25rem;margin:0;color:#285c38;font-size:.88rem;font-weight:700;text-align:center}.game-overlay-actions .btn{justify-content:center;min-width:min(100%,17rem);min-height:3.25rem;box-shadow:0 14px 28px #19346247}.mobile-controls{display:none;grid-template-columns:1fr 1fr;gap:.65rem}.mobile-controls .btn{justify-content:center;touch-action:manipulation}.high-score-panel{border:1px solid #c8d9f2;border-radius:12px;background:#f8fbff;overflow:hidden}.high-score-panel summary{min-height:2.85rem;display:flex;align-items:center;padding:.7rem .85rem;color:#234b8d;font-weight:800;cursor:pointer;-webkit-user-select:none;user-select:none}.high-score-panel summary::marker{color:#2b5fbf}.high-score-table{width:calc(100% - 1.7rem);margin:0 .85rem .85rem;border-collapse:collapse;color:#263f68;font-size:.92rem}.high-score-table th,.high-score-table td{padding:.5rem .35rem;border-top:1px solid #dce7f7;text-align:left}.high-score-table th{color:#234b8d;font-size:.78rem;font-weight:800;text-transform:uppercase}.high-score-table td{font-weight:700}.high-score-table th:first-child,.high-score-table td:first-child{width:3.25rem}.high-score-table th:last-child,.high-score-table td:last-child{width:5rem;color:#2b5fbf;text-align:right;font-variant-numeric:tabular-nums}.high-score-empty{margin:0;padding:0 .85rem .85rem;color:#5b6b83;font-weight:600}@media (max-width: 860px){.mobile-controls{display:grid}}@media (max-width: 640px){.page-shell h1{font-size:clamp(2rem,8vw,2.75rem);line-height:1.06}.page-shell .lead{font-size:.98rem;line-height:1.65}.game-wrap{padding:.8rem;gap:.8rem}.game-mount{border-radius:14px}.game-overlay-actions{padding:.8rem}.game-overlay-actions .btn{width:100%;min-height:3rem;font-size:.98rem}.game-result-popup{border-radius:14px;padding:1rem}.mobile-controls{gap:.55rem}.mobile-controls .btn{min-height:2.95rem;font-size:.98rem}}.coffee-page h1,.coffee-admin h1{margin-top:.15rem;font-size:clamp(2rem,4.2vw,3.2rem);line-height:1.08;letter-spacing:-.03em;color:#2b5fbf}@supports ((-webkit-background-clip: text) or (background-clip: text)){.coffee-page h1,.coffee-admin h1{background:linear-gradient(90deg,#2b5fbf,#4d82df 58%,#7caeff);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;color:transparent}}.coffee-slot-grid{margin-top:1rem;display:grid;gap:.65rem;grid-template-columns:repeat(auto-fit,minmax(210px,1fr))}.coffee-slot{border:1px solid #c8d8ef;border-radius:12px;padding:.75rem;background:linear-gradient(180deg,#f8fbff,#eef4ff);color:#274c88;text-align:left;display:grid;gap:.2rem;cursor:pointer}.coffee-slot.is-selected{border-color:#5d88d2;box-shadow:0 0 0 3px #5d88d23d}.coffee-slot:disabled{opacity:.6;cursor:not-allowed}.coffee-booking-form,.coffee-admin-form{margin-top:1rem}.coffee-booking-list{margin-top:.55rem;display:grid;gap:.35rem}.status-line{min-height:1.25rem;font-weight:600;color:#2f4f88}.coffee-admin-slots{margin-top:1rem;display:grid;gap:.65rem}:root{--bg: #eef3fb;--surface: #ffffff;--text: #1a2538;--muted: #5b6b83;--primary: #2b5fbf;--primary-strong: #234ea0;--secondary: #dce9ff;--accent: #89b6ff;--line: #d6e0f0;--shadow: 0 16px 40px rgba(24, 44, 84, .14);--radius-lg: 22px;--radius-md: 14px;--radius-sm: 10px}*{box-sizing:border-box}body{margin:0;min-height:100vh;font-family:Poppins,sans-serif;color:var(--text);background:radial-gradient(circle at 10% 5%,#dceaff 0%,transparent 42%),linear-gradient(150deg,#f8fbff,#e9f1fd);position:relative;overflow-x:hidden}h1,h2,h3,.eyebrow{font-family:Poppins,sans-serif;margin:0}h1{font-size:clamp(2rem,4vw,3.4rem);line-height:1.07;letter-spacing:-.02em}h2{margin-bottom:1rem;font-size:1.25rem}h3{margin-bottom:.5rem;font-size:1rem}p{margin:0;line-height:1.55;color:var(--muted)}.page{width:min(1120px,calc(100% - 2rem));margin:2rem auto 3rem;display:grid;gap:1.25rem}.card{background:linear-gradient(180deg,#fffffff5,#fcfdffe6);border:1px solid var(--line);border-radius:var(--radius-lg);box-shadow:var(--shadow);padding:1.4rem;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px);animation:rise .5s ease both}.hero{padding:clamp(1.4rem,3vw,2rem)}.eyebrow{text-transform:uppercase;letter-spacing:.12em;color:var(--primary);font-size:.75rem;margin-bottom:.6rem}.lead{max-width:none;margin-top:.8rem}.grid{display:grid;gap:1.25rem}.two-col{grid-template-columns:repeat(2,minmax(0,1fr))}.button-row{display:flex;flex-wrap:wrap;gap:.7rem;margin-top:1rem}.btn{border:0;border-radius:var(--radius-sm);font-weight:700;padding:.65rem 1rem;transition:transform .16s ease,box-shadow .16s ease,background-color .16s ease;cursor:pointer;display:inline-block;text-decoration:none}.btn:hover{transform:translateY(-2px)}.btn:disabled{cursor:not-allowed;opacity:.55;transform:none}.btn-primary{color:#fff;background:linear-gradient(180deg,var(--primary),var(--primary-strong));box-shadow:0 10px 20px #234ea04d}.btn-secondary{color:#1f4389;background:linear-gradient(180deg,var(--secondary),#c5dcff)}.btn-ghost{color:var(--primary-strong);border:1px solid #bfd0ea;background:#f4f8ff}.btn-pill{border-radius:999px;color:#23396b;background:linear-gradient(180deg,#bfd8ff,var(--accent))}.card-grid{display:grid;gap:.9rem}.mini-box{border-radius:var(--radius-md);border:1px solid #cad8ec;background:#f8fbff;padding:1rem}.mini-box.accent{background:linear-gradient(160deg,#eff6ff,#deebff);border-color:#b7cbeb}.badge{margin-top:.7rem;display:inline-block;font-size:.75rem;font-weight:700;padding:.35rem .55rem;border-radius:999px;color:#244687;background:#dce9ff}.badge.dark{color:#fff;background:#2f5fb3}.stack{display:grid;gap:.9rem}.form{display:grid;gap:.8rem}label{display:grid;gap:.35rem;font-weight:600}input,textarea{width:100%;border:1px solid #c9d8ed;border-radius:10px;padding:.7rem .8rem;font:inherit;color:#1f2f4a;background:#fbfdff}input:focus,textarea:focus{outline:none;border-color:#5d88d2;box-shadow:0 0 0 3px #5d88d23d}label.inline{display:flex;align-items:center;gap:.5rem;font-weight:500}label.inline input{width:auto}.alert{border-radius:var(--radius-sm);padding:.7rem .85rem;border:1px solid;font-weight:600}.alert.success{color:#214786;background:#e8f1ff;border-color:#bfd3f4}.alert.warn{color:#3c4e71;background:#edf3ff;border-color:#ccdaef}.pill-row{display:flex;flex-wrap:wrap;gap:.5rem}.pill{display:inline-block;font-size:.8rem;font-weight:700;color:#2f4d86;background:#edf4ff;border:1px solid #d1def3;border-radius:999px;padding:.35rem .7rem}.progress-wrap{display:grid;gap:.35rem}.progress-label{display:flex;justify-content:space-between;font-size:.9rem;font-weight:700;color:#2d4677}.progress-track{height:11px;border-radius:999px;background:#dbe5f5;overflow:hidden}.progress-bar{display:block;height:100%;width:68%;background:linear-gradient(90deg,#3164bf,#73a3ee)}.home-page{max-width:980px;gap:.55rem}.logo-slot{width:100%;margin-bottom:.05rem}.logo-image{display:block;width:100%;height:auto;mix-blend-mode:multiply;opacity:.97;filter:saturate(1.02) contrast(1.03);border-radius:8px}.top-nav{width:100%;margin:0;padding:.42rem .65rem;border:1px solid #c8d8ef;border-radius:var(--radius-lg);background:linear-gradient(180deg,#f4f8ff,#eaf1ff);display:flex;align-items:center;flex-wrap:nowrap;justify-content:space-between;gap:.35rem;box-shadow:0 6px 16px #182c5414;position:relative;z-index:40}.nav-toggle{display:none;width:100%;align-items:center;justify-content:space-between;gap:.75rem;border:0;border-radius:12px;background:transparent;color:#234b8d;font:inherit;font-size:.96rem;font-weight:700;padding:.72rem .8rem;cursor:pointer}.nav-toggle:hover{background:#ffffff73}.nav-toggle-bar{position:absolute;left:50%;display:block;width:1rem;height:2px;border-radius:999px;background:currentColor;transform:translate(-50%);transform-origin:center;transition:transform .18s ease,opacity .18s ease}.nav-toggle-icon{position:relative;display:inline-block;width:1.2rem;height:1.2rem}.nav-toggle-bar:nth-child(1){top:.22rem}.nav-toggle-bar:nth-child(2){top:50%;transform:translate(-50%,-50%)}.nav-toggle-bar:nth-child(3){bottom:.22rem}.top-nav.is-open .nav-toggle-bar:nth-child(1){top:50%;transform:translate(-50%,-50%) rotate(45deg)}.top-nav.is-open .nav-toggle-bar:nth-child(2){opacity:0}.top-nav.is-open .nav-toggle-bar:nth-child(3){bottom:auto;top:50%;transform:translate(-50%,-50%) rotate(-45deg)}.top-nav-links{display:flex;align-items:center;justify-content:space-between;gap:.35rem;width:100%}.top-nav-links .nav-link{display:inline-flex;align-items:center;gap:.25rem;flex:0 0 auto;white-space:nowrap;color:#2d4f8a;text-decoration:none;font-size:clamp(.64rem,.9vw,.82rem);font-weight:600;line-height:1;padding:.42rem .58rem;border-radius:var(--radius-md);transition:background-color .16s ease,color .16s ease,box-shadow .16s ease,transform .16s ease}.top-nav-links .nav-link:hover{background:#d7e7ff;color:#173a77;box-shadow:0 0 0 1px #afc8ef inset,0 0 16px #79a5e873;transform:translateY(-1px)}.top-nav-links .nav-link[aria-current=page]{background:#2b5fbf;color:#fff}.top-nav-links .nav-icon,.top-nav-links svg.nav-icon{width:1em;height:1em;min-width:1em;min-height:1em;flex:0 0 1em}.color-grid{margin-top:1rem;display:grid;gap:.9rem;grid-template-columns:repeat(3,minmax(0,1fr))}.color-card{border:1px solid #cddaf0;border-radius:var(--radius-md);padding:.9rem;background:#f8fbff}.swatch{width:100%;height:78px;border-radius:10px;background:var(--swatch);border:1px solid rgba(26,37,56,.12);margin-bottom:.75rem}.color-card p{margin-top:.35rem}.color-card code{font-family:ui-monospace,SFMono-Regular,Menlo,Consolas,Liberation Mono,monospace;background:#e8f0ff;color:#1f3d76;border:1px solid #c4d6f1;border-radius:6px;padding:.1rem .35rem}.bg-orb{position:fixed;z-index:-1;border-radius:50%;filter:blur(10px);opacity:.55}.bg-orb-a{width:320px;height:320px;right:-90px;top:20px;background:radial-gradient(circle at 25% 30%,#d7e7ff,#9ec1f4 75%)}.bg-orb-b{width:260px;height:260px;left:-90px;bottom:16px;background:radial-gradient(circle at 40% 35%,#dbe9ff,#adc8f1 85%)}@keyframes rise{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}@media (max-width: 860px){.two-col,.color-grid{grid-template-columns:1fr}.page{width:min(1120px,calc(100% - 1rem));margin-top:1rem}.top-nav{display:block}.top-nav-links{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));align-items:stretch;justify-content:stretch;gap:.35rem}.top-nav-links .nav-link{justify-content:center;min-width:0;white-space:normal;text-align:center;min-height:2.8rem}}@media (max-width: 640px){.page{width:min(1120px,calc(100% - .75rem));margin:.75rem auto 1.5rem;gap:.75rem}.card{padding:1rem;border-radius:18px}.hero{padding:1.15rem}.lead{margin-top:.7rem;font-size:.96rem;line-height:1.6}.button-row{gap:.6rem}.button-row .btn{width:100%;text-align:center}.top-nav{width:100%;max-width:100%;padding:0;border:0;background:transparent;box-shadow:none;overflow:hidden}.nav-toggle{display:none}.top-nav-links{display:flex;flex-wrap:nowrap;align-items:stretch;width:100%;max-width:100%;min-width:0;overflow-x:auto;overflow-y:hidden;-webkit-overflow-scrolling:touch;scrollbar-width:thin;scroll-snap-type:x proximity;gap:.55rem;padding-top:0}.top-nav.is-open .top-nav-links{display:flex}.top-nav-links .nav-link{flex:0 0 auto;scroll-snap-align:start;font-size:.9rem;font-weight:700;gap:.4rem;padding:.72rem .8rem;min-height:2.9rem;min-width:max-content;white-space:nowrap}.top-nav-links .nav-icon,.top-nav-links svg.nav-icon{width:1.05em;height:1.05em;min-width:1.05em;min-height:1.05em}}.app-shell{min-height:100vh}.app-shell .logo-image{height:auto}
