:root{--bg:#f1f5f9;--panel:#fff;--panel-soft:#f8fafc;--text:#0f172a;--muted:#64748b;--border:#dbe3ec;--border-strong:#cbd5e1;--blue:#2563eb;--blue-soft:#eff6ff;--blue-ring:#dbeafe;--green:#16a34a;--green-soft:#f0fdf4;--green-ring:#bbf7d0;--purple:#7c3aed;--purple-soft:#f5f3ff;--purple-ring:#ddd6fe;--amber:#d97706;--amber-soft:#fffbeb;--shadow:0 10px 24px #0f172a0f;color:var(--text);background:var(--bg);font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif}*{box-sizing:border-box}html{scrollbar-gutter:stable;overflow-y:scroll}body{min-width:320px;margin:0}button,input,select,textarea{font:inherit}button{cursor:pointer}button:disabled{cursor:not-allowed;opacity:.45}h1{letter-spacing:0;margin:0;font-size:28px;font-weight:700;line-height:1.1}p{color:var(--muted);margin:6px 0 0;font-size:14px}.icon svg{width:100%;height:100%;overflow:visible}strong{color:var(--text);text-overflow:ellipsis;white-space:nowrap;font-size:15px;font-weight:700;line-height:1.25;display:block;overflow:hidden}small{color:var(--muted);margin-top:4px;font-size:12px;line-height:1.25;display:block}.icon{width:16px;height:16px;color:var(--muted);flex:0 0 16px;justify-content:center;align-items:center;font-size:12px;line-height:1;display:inline-flex}.app-shell{min-height:100vh;padding:24px}.app-header{justify-content:space-between;align-items:center;gap:16px;max-width:1280px;min-height:52px;margin:0 auto 16px;display:flex}.app-header.is-landing{max-width:min(900px,100%)}.app-header-main{align-items:center;min-width:0;display:flex}.app-nav{flex:none;align-items:center;gap:8px;display:flex}.locale-switch{border:1px solid var(--border);background:var(--panel);border-radius:999px;align-items:center;display:inline-flex;overflow:hidden}.locale-switch-btn{appearance:none;color:var(--muted);letter-spacing:.04em;cursor:pointer;background:0 0;border:0;padding:4px 10px;font-size:.78rem;font-weight:600;transition:background .12s,color .12s}.locale-switch-btn:hover{color:var(--text)}.locale-switch-btn.is-active{background:var(--blue);color:#fff;cursor:default}.title-row{align-items:center;gap:12px;display:flex}.title-nav{align-items:center;gap:8px;display:flex}.title-nav a,.title-nav button{border:1px solid var(--border);color:#334155;background:#fff;border-radius:8px;align-items:center;min-height:34px;padding:0 10px;font-family:inherit;font-size:13px;font-weight:650;text-decoration:none;display:inline-flex}.title-nav a:hover,.title-nav a.is-active,.title-nav button:hover,.title-nav button.is-active{border-color:var(--blue);background:var(--blue-soft);color:var(--blue)}.title-nav a.title-nav-highlight,.title-nav button.title-nav-highlight{position:relative}.title-nav a.title-nav-highlight:after,.title-nav button.title-nav-highlight:after{content:"";border:1px dashed var(--green);pointer-events:none;border-radius:11px;position:absolute;inset:-4px}.title-nav a.title-nav-highlight-purple,.title-nav button.title-nav-highlight-purple{position:relative}.title-nav a.title-nav-highlight-purple:after,.title-nav button.title-nav-highlight-purple:after{content:"";border:1px dashed var(--purple);pointer-events:none;border-radius:11px;position:absolute;inset:-4px}.volunteer-nav-group{border:1px dashed var(--green);border-radius:8px;align-items:center;gap:8px;padding:2px;display:flex}.admin-nav-group{border:1px dashed var(--blue);border-radius:8px;align-items:center;gap:8px;padding:2px;display:flex}.title-nav .volunteer-nav-group a,.title-nav .volunteer-nav-group button{border-color:var(--green-ring);color:var(--green)}.title-nav .volunteer-nav-group a:hover,.title-nav .volunteer-nav-group a.is-active,.title-nav .volunteer-nav-group button:hover,.title-nav .volunteer-nav-group button.is-active{border-color:var(--green);background:var(--green-soft);color:var(--green)}.title-nav .admin-nav-group a,.title-nav .admin-nav-group button{border-color:var(--blue-ring);color:var(--blue)}.title-nav .admin-nav-group a:hover,.title-nav .admin-nav-group a.is-active,.title-nav .admin-nav-group button:hover,.title-nav .admin-nav-group button.is-active{border-color:var(--blue);background:var(--blue-soft);color:var(--blue)}.title-nav a.title-nav-highlight-purple,.title-nav button.title-nav-highlight-purple{border-color:var(--purple-ring);color:var(--purple)}.title-nav a.title-nav-highlight-purple:hover,.title-nav a.title-nav-highlight-purple.is-active,.title-nav button.title-nav-highlight-purple:hover,.title-nav button.title-nav-highlight-purple.is-active{border-color:var(--purple);background:var(--purple-soft);color:var(--purple)}.public-welcome{color:var(--muted);font-size:13px;font-weight:800}.public-welcome strong{color:var(--text);white-space:normal;margin-left:4px;font-size:13px;display:inline}strong.welcome-super{color:#7c3aed}strong.welcome-admin{color:var(--blue)}strong.welcome-volunteer{color:#16a34a}.role-tag{text-transform:uppercase;letter-spacing:.04em;border-radius:999px;padding:2px 8px;font-size:11px;font-weight:700;display:inline-block}.role-tag-super{color:#7c3aed;background:#ede9fe}.role-tag-admin{background:var(--blue-soft);color:var(--blue)}.role-tag-volunteer{color:#15803d;background:#dcfce7}.public-logout{margin-left:auto}.header-login-button{border:1px solid var(--blue);background:var(--blue-soft);color:var(--blue);border-radius:8px;padding:6px 14px;font-size:14px;font-weight:500;text-decoration:none}.header-login-button:hover{background:var(--blue);color:#fff}.header-drawer-auth{gap:8px;display:grid}.header-drawer-auth .header-login-button,.header-drawer-auth .header-signup-button{appearance:none;font:inherit;cursor:pointer;text-align:center;border-radius:8px;padding:10px 14px}.header-signup-button{border:1px solid var(--blue);background:var(--blue);color:#fff;font-size:14px;font-weight:600}.header-signup-button:hover{background:#1d4ed8;border-color:#1d4ed8}.family-menu{position:relative}.menu-icon-button{border:1px solid var(--border);color:#334155;background:#fff;border-radius:8px;justify-content:center;align-items:center;width:38px;height:34px;padding:7px 9px;display:inline-flex}.menu-icon-button:hover,.menu-icon-button[aria-expanded=true]{border-color:var(--blue);background:var(--blue-soft)}.family-menu-popover{z-index:20;border:1px solid var(--border);width:min(320px,100vw - 32px);box-shadow:var(--shadow);background:#fff;border-radius:8px;gap:10px;padding:12px;display:grid;position:absolute;top:calc(100% + 8px);right:0}.family-menu-header{border-bottom:1px solid var(--border);gap:2px;padding-bottom:10px;display:grid}.family-menu-header span,.family-menu-empty{color:var(--muted);font-size:12px;font-weight:700}.family-menu-header strong{white-space:normal;min-width:0;font-size:13px}.family-menu-section{gap:8px;margin-top:6px;display:grid}.family-menu-section-title{gap:2px;display:grid}.family-menu-section-title span{color:var(--text);font-size:13px;font-weight:800}.family-menu-section-title small{color:var(--muted);margin:0;font-size:12px;font-weight:700}.family-menu-actions,.family-member-selector{gap:6px;display:grid}.family-member-current{border:1px solid var(--border);width:100%;color:var(--text);text-align:left;cursor:pointer;background:#fff;border-radius:8px;grid-template-columns:minmax(0,1fr) auto;align-items:stretch;gap:6px;padding:6px;display:grid}.family-member-current:hover{border-color:var(--blue);background:var(--blue-soft)}.family-member-select-label{gap:5px;min-width:0;display:grid}.family-member-select-label span{color:var(--muted);font-size:12px;font-weight:700}.family-member-select-label strong{white-space:normal;min-width:0;font-size:14px}.family-menu-action{border:1px solid var(--border);width:100%;color:var(--text);text-align:left;background:#fff;border-radius:8px;padding:10px;text-decoration:none}.family-menu-action:hover{border-color:var(--blue);background:var(--blue-soft)}.family-menu-action-centered{text-align:center;justify-content:center;align-items:center;display:flex}.family-member-edit{border:1px solid var(--border);color:#334155;background:#fff;border-radius:8px;justify-content:center;align-self:center;align-items:center;width:32px;height:32px;min-height:32px;padding:0;text-decoration:none;display:inline-flex}.family-member-edit:hover{border-color:var(--blue);color:var(--blue)}.family-member-edit .icon{width:16px;height:16px;color:inherit}.family-member-details{grid-column:1/-1;gap:2px;padding:0 4px 2px;display:grid}.family-member-details small{margin:0}.member-picker-list{gap:8px;width:100%;display:grid}.member-picker-item{border:1px solid var(--border);width:100%;color:var(--text);text-align:left;background:#fff;border-radius:8px;gap:2px;padding:10px 12px;display:grid}.member-picker-item:hover,.member-picker-item.is-active{border-color:var(--blue);background:var(--blue-soft)}.family-menu-action{font-size:13px;font-weight:800;display:block}.app-nav a{border:1px solid var(--border);color:#334155;background:#fff;border-radius:8px;align-items:center;min-height:34px;padding:0 10px;font-size:13px;font-weight:650;text-decoration:none;display:inline-flex}.app-nav a:hover,.app-nav a.is-active{border-color:var(--blue);background:var(--blue-soft);color:var(--blue)}.app-header h1{align-items:center;display:flex}.home-title{color:inherit;align-items:center;text-decoration:none;display:inline-flex}.home-title img{width:auto;height:52px;display:block}.home-title:hover{color:var(--blue)}.section-heading{max-width:1280px;margin:0 auto 10px}.section-heading:first-of-type{text-align:left;max-width:1040px}.section-heading.volunteers-heading{text-align:left;max-width:1280px}.section-heading h2{letter-spacing:0;margin:0;font-size:20px;line-height:1.15}.section-heading p{margin-top:4px;font-size:13px}.needs-page{grid-template-columns:minmax(170px,.85fr) minmax(170px,.85fr) minmax(170px,.85fr) minmax(300px,1.25fr);align-items:start;gap:16px;max-width:1280px;margin:0 auto;display:grid}.needs-page>.panel,.commission-needs-page>.panel{min-height:0;max-height:calc(100dvh - 220px)}.needs-page>.panel>.panel-body,.commission-needs-page>.panel>.panel-body{scrollbar-width:thin;scrollbar-color:transparent transparent;scrollbar-gutter:stable both-edges;flex:auto;min-height:0;padding-left:4px;padding-right:4px;transition:scrollbar-color .2s;overflow:auto}.needs-page>.panel>.panel-body.is-scrolling,.commission-needs-page>.panel>.panel-body.is-scrolling{scrollbar-color:#94a3b899 transparent}.needs-page>.panel>.panel-body::-webkit-scrollbar{width:4px;height:4px}.commission-needs-page>.panel>.panel-body::-webkit-scrollbar{width:4px;height:4px}.needs-page>.panel>.panel-body::-webkit-scrollbar-track{background:0 0}.commission-needs-page>.panel>.panel-body::-webkit-scrollbar-track{background:0 0}.needs-page>.panel>.panel-body::-webkit-scrollbar-thumb{background:0 0;border-radius:999px;transition:background .2s}.commission-needs-page>.panel>.panel-body::-webkit-scrollbar-thumb{background:0 0;border-radius:999px;transition:background .2s}.needs-page>.panel>.panel-body.is-scrolling::-webkit-scrollbar-thumb{background:#94a3b899}.commission-needs-page>.panel>.panel-body.is-scrolling::-webkit-scrollbar-thumb{background:#94a3b899}.needs-carousel-dots{display:none}@media (width<=980px){.needs-carousel-dots{justify-content:center;gap:8px;padding:12px 0 4px;display:flex}.needs-carousel-dot{appearance:none;cursor:pointer;background:#94a3b873;border:0;border-radius:50%;width:8px;height:8px;padding:0;transition:background .2s,transform .2s}.needs-carousel-dot.is-active{background:var(--accent,#2563eb);transform:scale(1.3)}}.needs-page>.panel>.panel-body::-webkit-scrollbar-button{background:0 0;width:0;height:0;display:none}.commission-needs-page>.panel>.panel-body::-webkit-scrollbar-button{background:0 0;width:0;height:0;display:none}.needs-page>.panel>.panel-body::-webkit-scrollbar-button:start:decrement{background:0 0;width:0;height:0;display:none}.commission-needs-page>.panel>.panel-body::-webkit-scrollbar-button:start:decrement{background:0 0;width:0;height:0;display:none}.needs-page>.panel>.panel-body::-webkit-scrollbar-button:end:increment{background:0 0;width:0;height:0;display:none}.commission-needs-page>.panel>.panel-body::-webkit-scrollbar-button:end:increment{background:0 0;width:0;height:0;display:none}.needs-page>.panel>.panel-body::-webkit-scrollbar-button:vertical:start{background:0 0;width:0;height:0;display:none}.commission-needs-page>.panel>.panel-body::-webkit-scrollbar-button:vertical:start{background:0 0;width:0;height:0;display:none}.needs-page>.panel>.panel-body::-webkit-scrollbar-button:vertical:end{background:0 0;width:0;height:0;display:none}.commission-needs-page>.panel>.panel-body::-webkit-scrollbar-button:vertical:end{background:0 0;width:0;height:0;display:none}.needs-page>.panel>.panel-body::-webkit-scrollbar-button:horizontal:start{background:0 0;width:0;height:0;display:none}.commission-needs-page>.panel>.panel-body::-webkit-scrollbar-button:horizontal:start{background:0 0;width:0;height:0;display:none}.needs-page>.panel>.panel-body::-webkit-scrollbar-button:horizontal:end{background:0 0;width:0;height:0;display:none}.commission-needs-page>.panel>.panel-body::-webkit-scrollbar-button:horizontal:end{background:0 0;width:0;height:0;display:none}.needs-toolbar{justify-content:flex-start;max-width:1280px;margin:0 auto 12px;display:flex}.needs-controls-row{justify-content:center;align-items:start;gap:16px;max-width:1280px;margin:0 auto 16px;display:flex}.needs-controls-row .needs-toolbar,.needs-controls-row .mode-switch-wrap{max-width:none;margin:0}.needs-controls-row .needs-toolbar{justify-self:start}.needs-controls-switch{justify-self:center}.needs-toolbar-actions{border:1px solid var(--border);background:var(--panel);width:fit-content;max-width:100%;box-shadow:var(--shadow);border-radius:10px;flex-wrap:wrap;justify-content:flex-start;align-items:center;gap:6px;padding:4px;display:inline-flex}.needs-toolbar-actions button{justify-content:center;align-items:center;min-height:34px;padding:0 10px;font-size:13px;font-weight:650;display:inline-flex}.needs-toolbar-message{margin:0}.mode-switch-wrap{justify-content:center;max-width:1280px;margin:0 auto 16px;display:flex}.mode-switch-stack{justify-items:center;gap:8px;display:grid}.mode-switch{border:1px solid var(--border);background:var(--panel);box-shadow:var(--shadow);border-radius:10px;gap:6px;padding:4px;display:inline-flex}.mode-switch button{color:#334155;background:0 0;border:0;border-radius:8px;min-width:132px;min-height:34px;padding:0 12px;font-size:13px;font-weight:650}.mode-switch button:hover{background:var(--panel-soft)}.mode-switch button.is-active{background:var(--blue-soft);color:var(--blue)}.mode-switch-description{text-align:center;margin:0;font-size:13px}@media (width<=480px){.mode-switch button{flex:1 1 0;min-width:0;padding:0 8px;font-size:12px}.mode-switch,.mode-switch-wrap{width:100%}.mode-switch-description{font-size:12px}}.single-panel-page{max-width:1280px;margin:0 auto}.commission-management-page{grid-template-columns:minmax(320px,.82fr) minmax(500px,1.18fr);align-items:start;gap:16px;max-width:1280px;margin:0 auto;display:grid}.commission-management-sidebar{gap:16px;display:grid}.news-page{max-width:900px;margin:0 auto}.participate-page{place-items:center;min-height:calc(100vh - 176px);padding:24px 0;display:grid}.landing-page{align-content:center;justify-items:center;gap:24px;position:relative}.landing-top-actions{position:absolute;top:20px;right:20px}.landing-logo{width:min(560px,100vw - 32px);height:auto;display:block}.landing-news{width:min(900px,100%)}.participate-panel{border:1px solid var(--border);background:var(--panel);width:min(900px,100%);box-shadow:var(--shadow);border-radius:8px;gap:18px;padding:24px;display:grid}.participate-panel h2{letter-spacing:0;margin:0;font-size:26px;line-height:1.2}.participate-actions{grid-template-columns:1fr 1fr;gap:12px;display:grid}.participate-card{border:1px solid var(--border);min-height:120px;color:var(--text);background:#fff;border-radius:8px;align-content:center;gap:6px;padding:18px;text-decoration:none;display:grid}.participate-card:hover{border-color:var(--blue);background:var(--blue-soft);box-shadow:0 0 0 3px var(--blue-ring)}.participate-actions.is-disabled .participate-card{cursor:not-allowed;background:var(--panel-soft);color:var(--muted);opacity:.55;pointer-events:none}.participate-actions.is-disabled .participate-card:hover{border-color:var(--border);background:var(--panel-soft);box-shadow:none}.noticias-admin-panel{gap:0;display:grid}.noticias-admin-toolbar{border-bottom:1px solid var(--border);padding:12px 16px}.news-admin-item{border-top:none;border-left:none;border-right:none;border-radius:0}.news-admin-actions{justify-content:flex-end;gap:8px;display:flex}.news-list{gap:12px;padding:16px;display:grid}.news-item{border:1px solid var(--border);background:#fff;border-radius:8px;gap:8px;padding:16px;display:grid}.news-item-header{justify-content:space-between;align-items:flex-start;gap:12px;display:flex}.news-item h3{color:var(--text);letter-spacing:0;margin:0;font-size:18px;line-height:1.2}.news-item time{color:var(--muted);flex:none;font-size:12px;font-weight:800}.news-item p{color:#334155;white-space:pre-wrap;margin:0;line-height:1.5}.news-item.is-compact p{-webkit-line-clamp:3;-webkit-box-orient:vertical;display:-webkit-box;overflow:hidden}.news-read-more{color:var(--blue);font-size:13px;font-weight:700;text-decoration:none}.news-read-more:hover{text-decoration:underline}.export-page{max-width:1280px;margin:0 auto}.export-grid{grid-template-columns:1fr 1fr;gap:12px;padding:16px;display:grid}.export-card{border:1px solid var(--border);background:#fff;border-radius:8px;gap:12px;padding:16px;display:grid}.export-card h3{letter-spacing:0;margin:0;font-size:18px;line-height:1.2}.export-actions{flex-wrap:wrap;gap:8px;display:flex}.export-message{color:#166534;background:#f0fdf4;border:1px solid #bbf7d0;border-radius:8px;margin:0 16px 16px;padding:10px 12px;font-size:13px;font-weight:700}.coverage-progress span{color:var(--muted);font-size:14px;font-weight:700}.header-hamburger{border:1px solid var(--border);background:var(--panel);width:44px;height:44px;color:var(--text);cursor:pointer;border-radius:8px;flex-shrink:0;justify-content:center;align-items:center;padding:0;display:inline-flex}.header-hamburger:hover{background:var(--panel-soft)}.header-drawer-backdrop{z-index:50;background:#0f172a73;justify-content:flex-end;display:flex;position:fixed;inset:0}.header-drawer{background:var(--panel);flex-direction:column;gap:16px;width:min(320px,85vw);height:100dvh;padding:16px;animation:.22s ease-out header-drawer-slide-in;display:flex;overflow-y:auto;box-shadow:-8px 0 24px #00000026}@keyframes header-drawer-slide-in{0%{transform:translate(100%)}to{transform:translate(0)}}.header-drawer-top{justify-content:space-between;align-items:center;gap:12px;display:flex}.header-drawer-top-left{align-items:center;gap:8px;display:flex}.header-drawer-close{appearance:none;color:var(--muted);cursor:pointer;background:0 0;border:0;border-radius:8px;width:36px;height:36px;font-size:28px;line-height:1}.header-drawer-close:hover{background:var(--panel-soft);color:var(--text)}.header-drawer-nav{flex-direction:column;gap:16px;display:flex}.header-drawer-nav-group{flex-direction:column;gap:6px;display:flex}.header-drawer-nav-group a{border:1px solid var(--border);background:var(--panel);text-align:left;border-radius:8px;padding:12px 14px;font-weight:600;text-decoration:none;display:block}.header-drawer-nav-group.is-volunteer a{border-color:var(--green-ring);color:var(--green)}.header-drawer-nav-group.is-volunteer a:hover,.header-drawer-nav-group.is-volunteer a.is-active{border-color:var(--green);background:var(--green-soft);color:var(--green)}.header-drawer-nav-group.is-admin a{border-color:var(--blue-ring);color:var(--blue)}.header-drawer-nav-group.is-admin a:hover,.header-drawer-nav-group.is-admin a.is-active{border-color:var(--blue);background:var(--blue-soft);color:var(--blue)}.header-drawer-nav-group.is-super a{border-color:var(--purple-ring);color:var(--purple)}.header-drawer-nav-group.is-super a:hover,.header-drawer-nav-group.is-super a.is-active{border-color:var(--purple);background:var(--purple-soft);color:var(--purple)}.header-drawer-logout{border:1px solid var(--border);background:var(--panel);cursor:pointer;border-radius:8px;margin-top:auto;padding:12px 14px;font-weight:600}.header-welcome{color:var(--muted);text-align:right;text-overflow:ellipsis;white-space:nowrap;flex:auto;justify-content:flex-end;align-items:center;gap:4px;min-width:0;padding:0 8px;font-size:13px;display:inline-flex;overflow:hidden}.header-welcome strong{text-overflow:ellipsis;overflow:hidden}@media (width<=600px){.header-welcome{white-space:normal;text-overflow:clip;flex-direction:column;align-items:flex-end;gap:0;line-height:1.25}}.family-menu-backdrop{z-index:99;background:#0f172a80;animation:.2s ease-out family-menu-fade-in;position:fixed;inset:0}@keyframes family-menu-fade-in{0%{opacity:0}to{opacity:1}}.family-menu-popover-floating{z-index:100;transform-origin:50%;width:min(360px,100vw - 32px);max-height:80dvh;animation:.38s cubic-bezier(.34,1.7,.64,1) family-menu-boing;position:fixed;top:50%;left:50%;right:auto;overflow-y:auto;transform:translate(-50%,-50%)}.family-menu-close{appearance:none;color:var(--muted);cursor:pointer;z-index:1;background:0 0;border:0;border-radius:8px;width:32px;height:32px;font-size:24px;line-height:1;position:absolute;top:6px;right:6px}.family-menu-close:hover{background:var(--panel-soft);color:var(--text)}.family-menu-popover{position:relative}.family-menu-popover-floating{position:fixed}.modal-backdrop.family-member-picker-backdrop{z-index:120}@keyframes family-menu-boing{0%{opacity:0;transform:translate(-50%,-50%)scale(.4)}60%{opacity:1;transform:translate(-50%,-50%)scale(1.08)}80%{transform:translate(-50%,-50%)scale(.96)}to{transform:translate(-50%,-50%)scale(1)}}@media (width<=980px){.app-shell{padding:16px}.title-row{flex-wrap:wrap}.email-access-form,.profile-switcher,.email-consents-grid{grid-template-columns:1fr}.email-consents-grid .consents-title,.email-consents-grid .contact-auth-title,.email-consents-grid .identity-legal,.email-consents-grid .identity-contact,.email-consents-grid .contact-method-field{grid-area:auto}.catalog-row{flex-wrap:wrap}.catalog-row-fields{flex-direction:column}.catalog-row-fields-grid{flex-direction:row}.identity-fields{grid-template-columns:1fr}.name-fields-row{flex-direction:column;grid-column:auto}.phone-field,.relation-field,.class-field,.dni-field,.age-field,.basque-field,.consents-title,.identity-legal,.contact-auth-title,.identity-contact,.contact-method-field{grid-area:auto}.participate-actions,.news-form{grid-template-columns:1fr}.needs-controls-row{grid-template-columns:1fr;justify-items:center}.needs-controls-row .needs-toolbar,.needs-controls-switch{justify-self:center}.needs-toolbar-actions button{width:auto}.news-item-header{display:grid}.status-header-side{flex-direction:column-reverse;align-items:stretch;width:100%}.status-header-actions{justify-content:stretch}.status-header-actions button{width:100%}.export-grid{grid-template-columns:1fr}.needs-page{scroll-snap-type:x mandatory;touch-action:pan-x;scrollbar-width:none;grid-template-columns:none;gap:16px;margin-inline:-16px;padding-inline:32px;display:flex;overflow:auto hidden}.needs-page::-webkit-scrollbar{display:none}.needs-page>.panel{scroll-snap-align:center;scroll-snap-stop:always;flex:0 0 calc(100vw - 64px);max-height:calc(100dvh - 280px)}.needs-page>.panel>.panel-body{padding-left:12px;padding-right:12px}.commission-management-page,.commissions-builder{grid-template-columns:1fr}.commission-card-top{flex-direction:column;align-items:stretch}.commission-cards-list{grid-template-columns:1fr}.commission-card-heading{flex-direction:column;align-items:flex-start}.commission-card-title-row,.commission-card-actions{flex-wrap:wrap}.commission-card-body{grid-template-columns:1fr}.commission-signup-title{align-items:flex-start}.commission-signup-footer{flex-direction:column;align-items:stretch}.commission-signup-cta{align-items:stretch}.commission-signup-cta button{width:100%}.panel{min-height:260px}.panel.collapsible-panel.is-collapsed{min-height:0}.slot-creator,.slot-card,.signup-slot,.commission-need-card,.commission-needs-form{grid-template-columns:1fr}.commission-needs-form button{width:100%}.my-turn-note-col{width:auto;min-width:220px}.my-turn-note-popover{width:min(280px,100vw - 48px)}.slot-creator-actions,.slot-editor-actions{flex-direction:column}.slot-creator-actions button,.slot-editor-actions button{width:100%}.commission-action-stack{flex-direction:column}.commission-action-stack button{width:100%}.volunteer-stepper{justify-content:space-between}}.note-edit-button{border:1px solid var(--border);color:#334155;background:#fff;border-radius:8px;justify-content:center;align-items:center;width:28px;height:28px;padding:0;font-size:14px;font-weight:800;line-height:1;display:inline-flex}.note-edit-button:hover{border-color:var(--blue);background:var(--blue-soft);color:var(--blue)}.note-edit-button .icon{width:14px;height:14px;color:inherit;font-size:14px}.panel{border:1px solid var(--border);background:var(--panel);box-shadow:var(--shadow);border-radius:8px;flex-direction:column;display:flex}.panel-header{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;gap:12px;min-height:56px;padding:12px 14px;display:flex}.collapsible-panel.is-collapsed .panel-header{border-bottom:none;min-height:40px;padding:6px 14px}.collapsible-panel-toggle{cursor:pointer;min-width:0;color:inherit;text-align:left;font:inherit;background:0 0;border:none;flex:1;align-items:center;gap:8px;margin:0;padding:0;display:inline-flex}.collapsible-panel-toggle:focus-visible{outline:2px solid var(--blue);outline-offset:2px;border-radius:4px}.collapsible-panel-chevron{width:14px;height:14px;color:var(--muted);transition:color .15s;display:inline-flex}.collapsible-panel-toggle:hover .collapsible-panel-chevron{color:var(--text)}.panel-title,.panel-action,.slot-label,.volunteer-stepper,.volunteer-stepper span{align-items:center;display:inline-flex}.panel-title{gap:8px;font-size:14px;font-weight:700}.panel-action,.ghost-button,.primary-button{border:1px solid var(--border);color:#334155;background:#fff;border-radius:8px;min-height:34px;padding:0 10px;font-size:13px;font-weight:650}.panel-action{gap:6px}.panel-action:hover,.ghost-button:hover{border-color:var(--border-strong);background:var(--panel-soft)}.panel-body{padding:12px;overflow:visible}.card-wrap+.card-wrap,.slots-list>*+*{margin-top:8px}.card-urgency-badge{z-index:5;letter-spacing:.02em;pointer-events:none;-webkit-user-select:none;user-select:none;white-space:nowrap;border:none;border-radius:999px;align-items:center;padding:1px 7px;font-size:10px;font-weight:700;line-height:1.5;display:inline-flex;position:absolute;top:0;left:50%;transform:translate(-50%,-50%)}.card-urgency-badge-red{color:#b91c1c;background:#fee2e2;animation:1.5s ease-in-out infinite card-urgency-pulse}.card-urgency-badge-yellow{color:#92400e;background:#fef3c7}@keyframes card-urgency-pulse{0%,to{transform:translate(-50%,-50%)scale(1);box-shadow:0 0 #dc262673}50%{transform:translate(-50%,-50%)scale(1.08);box-shadow:0 0 0 5px #dc262600}}@media (prefers-reduced-motion:reduce){.card-urgency-badge-red{animation:none}}.card-urgency-dot{z-index:5;pointer-events:none;border-radius:999px;width:11px;height:11px;position:absolute;top:0;left:0;transform:translate(-50%,-50%);box-shadow:0 0 0 2px #fff}.card-urgency-dot-red{background:#fee2e2;border:1px solid #b91c1c}.card-urgency-dot-yellow{background:#fef3c7;border:1px solid #92400e}.selectable-card,.slot-card{border:1px solid var(--border);width:100%;color:var(--text);background:#fff;border-radius:8px;transition:border-color .15s,background .15s,box-shadow .15s}.selectable-card{text-align:left;justify-content:space-between;align-items:center;gap:12px;padding:12px;display:flex}.card-wrap--stacked .selectable-card{flex-direction:column;justify-content:space-between;align-items:stretch;gap:10px;min-height:84px}.card-wrap--stacked .selectable-card>span:first-child{width:100%}.card-wrap--stacked .selectable-card .card-actions{align-self:flex-end}.event-min-per-gela{flex-wrap:wrap;align-items:center;gap:10px;width:100%;display:flex}.event-min-per-gela-label{color:var(--muted);align-items:center;gap:6px;font-size:13px;display:flex}.event-min-per-gela-input{border:1px solid var(--border);background:var(--panel);width:70px;font:inherit;text-align:right;border-radius:6px;padding:4px 6px;font-size:13px}.event-min-per-gela-input:focus{border-color:var(--blue);box-shadow:0 0 0 2px var(--blue-ring);outline:none}.event-min-per-gela-hint{color:var(--muted);font-size:12px}.selectable-card:hover,.slot-card:hover{border-color:var(--border-strong);background:var(--panel-soft)}.selectable-card.is-selected,.slot-card.is-selected{border-color:var(--blue);background:var(--blue-soft);box-shadow:0 0 0 3px var(--blue-ring)}.selectable-card.is-editing,.inline-editor{border-color:var(--amber);background:var(--amber-soft)}.selectable-card.is-past,.slot-card.is-past{opacity:.55;background:var(--panel-soft)}.selectable-card.is-past:hover,.slot-card.is-past:hover{border-color:var(--border);background:var(--panel-soft)}.selectable-card span,.slot-main{min-width:0}.empty-state{border:1px dashed var(--border-strong);background:var(--panel-soft);color:var(--muted);text-align:center;border-radius:8px;padding:18px;font-size:14px}.commission-cards-list>.card-wrap{height:100%;margin-top:0}.card-wrap{position:relative}.area-documents-clip{z-index:2;background:var(--blue);color:#fff;pointer-events:none;border-radius:999px;align-items:center;gap:4px;padding:4px 9px;font-size:12px;font-weight:700;line-height:1;display:inline-flex;position:absolute;top:-8px;right:-8px;box-shadow:0 1px 4px #0f172a38}.area-documents-clip .icon{width:12px;height:12px;color:inherit;flex:0 0 12px}.area-documents-clip .icon svg{width:12px;height:12px}.area-documents-clip small{color:inherit;font-size:inherit;font-weight:inherit;line-height:inherit;margin:0;display:inline}.area-documents-modal{border:1px solid var(--border);background:#fff;border-radius:8px;gap:12px;width:min(640px,100%);max-height:calc(100vh - 40px);padding:20px;display:grid;overflow-y:auto;box-shadow:0 24px 60px #0f172a38}.area-documents-modal .modal-header{justify-content:space-between;align-items:center;gap:12px;display:flex}.area-documents-modal .modal-header h2{margin:0;font-size:18px;line-height:1.2}.area-documents-modal .modal-body{gap:18px;display:grid}.area-documents-list ul{gap:6px;margin:0;padding:0;list-style:none;display:grid}.area-documents-item{border:1px solid var(--border);background:var(--panel-soft);border-radius:6px;grid-template-columns:1fr auto auto;align-items:center;gap:10px;padding:8px 12px;display:grid}.area-documents-filename{text-overflow:ellipsis;white-space:nowrap;font-weight:500;overflow:hidden}.area-documents-size{color:var(--muted);font-size:12px}.area-documents-attach-row{flex-wrap:wrap;align-items:center;gap:8px;display:flex}.area-documents-attach-row select{border:1px solid var(--border-strong);min-width:200px;height:38px;min-height:38px;color:var(--text);background:#fff;border-radius:8px;flex:1;padding:0 10px}.area-documents-attach-row select:focus{outline:2px solid var(--blue,#4338ca);outline-offset:1px}.area-documents-upload-link{color:var(--muted);align-items:baseline;gap:6px;margin-top:6px;font-size:12px;display:flex}.area-documents-upload-link button{color:var(--blue,#4338ca);font:inherit;cursor:pointer;background:0 0;border:none;padding:0;font-weight:600;text-decoration:underline}.area-documents-upload-link button:disabled{opacity:.6;cursor:default}.documents-admin-panel{gap:12px;display:grid}.documents-admin-toolbar{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:12px;display:flex}.documents-admin-stats{color:var(--muted);align-items:center;gap:6px;font-size:13px;display:flex}.documents-admin-list{gap:8px;margin:0;padding:0;list-style:none;display:grid}.documents-admin-item{border:1px solid var(--border);background:#fff;border-radius:8px;justify-content:space-between;align-items:center;gap:12px;padding:10px 14px;display:flex}.documents-admin-item-main{gap:2px;min-width:0;display:grid}.documents-admin-item-main strong{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.documents-admin-item-main small{color:var(--muted);font-size:12px}.documents-admin-item-actions{flex-wrap:wrap;flex-shrink:0;gap:6px;display:flex}@media (width<=768px){.documents-admin-item{flex-direction:column;align-items:stretch;gap:10px}.documents-admin-item-actions{justify-content:flex-end}.documents-admin-item-actions button{flex:auto}}.toolbar-icon-button{border-radius:8px;justify-content:center;align-items:center;width:38px;min-width:38px;height:38px;min-height:38px;padding:0;display:inline-flex}.toolbar-icon-button .icon{width:22px;height:22px;color:inherit;flex:0 0 22px}.identity-panel{border:1px solid var(--border);background:var(--panel);max-width:1040px;box-shadow:var(--shadow);border-radius:8px;margin:0 auto 16px;padding:14px}.identity-fields{grid-template-columns:repeat(2,minmax(260px,360px));justify-content:center;gap:12px;display:grid}@media (width<=600px){.identity-fields{grid-template-columns:minmax(0,280px);justify-content:center}.identity-fields>*{grid-area:auto/1/auto/-1;min-width:0}.name-fields-row{flex-direction:column;gap:12px}.identity-panel input,.identity-panel select,.identity-panel textarea{box-sizing:border-box;width:100%;min-width:0}.member-form-modal{border-radius:12px;padding:16px;overflow-x:hidden}.modal-backdrop{padding:8px}}.email-access-mode-tabs{border-bottom:1px solid var(--border);margin-bottom:20px;display:flex}.email-access-tab{color:var(--muted);cursor:pointer;background:0 0;border:none;border-bottom:2px solid #0000;flex:1;margin-bottom:-1px;padding:10px;font-size:15px;font-weight:500}.email-access-tab.is-active{color:var(--blue);border-bottom-color:var(--blue)}.email-access-tab:hover:not(.is-active){color:var(--text)}.email-access-panel{border:1px solid var(--border);background:var(--panel);width:min(760px,100%);box-shadow:var(--shadow);border-radius:8px;margin:0 auto 16px;padding:14px}.public-login-panel{width:min(520px,100%)}.public-login-heading{text-align:center;max-width:none;margin:0 0 12px}.profile-summary-panel{text-align:center;padding:18px 20px}.profile-summary-text{color:var(--muted);margin:0;font-size:20px;line-height:1.35}.profile-summary-text strong{color:var(--text);font-size:inherit;white-space:normal;display:inline;overflow:visible}.profile-summary-note{margin-top:6px;font-size:14px}.profile-switcher{grid-template-columns:minmax(260px,420px) auto;justify-content:center;align-items:end;gap:10px;max-width:1040px;margin:0 auto 16px;display:grid}.profile-switcher label{gap:6px;display:grid}.profile-switcher span{color:var(--muted);font-size:12px;font-weight:700}.profile-switcher select{border:1px solid var(--border-strong);height:38px;min-height:38px;color:var(--text);background:#fff;border-radius:8px;outline:none;padding:0 10px}.profile-switcher select:focus{border-color:var(--blue);box-shadow:0 0 0 3px var(--blue-ring)}.email-access-form{grid-template-columns:1fr;align-items:stretch;gap:12px;display:grid}.email-consents-grid{grid-template-columns:1fr;gap:12px;display:grid}.email-consents-grid .consents-title{grid-area:1/1/auto/span 1}.email-consents-grid .contact-auth-title{grid-area:1/2/auto/span 1}.email-consents-grid .identity-legal{grid-area:2/1/auto/span 1}.email-consents-grid .identity-contact{grid-area:2/2/auto/span 1}.email-consents-grid .contact-method-field{grid-area:2/3/auto/span 1}.email-access-form .primary-button{justify-self:center;width:96px;height:38px;min-height:38px;padding:0 12px}.email-access-form label{gap:6px;display:grid}.email-access-form span{color:var(--muted);font-size:12px;font-weight:700}.email-access-form em{color:#dc2626;font-style:normal}.email-access-form input,.email-access-panel select{border:1px solid var(--border-strong);height:38px;min-height:38px;color:var(--text);background:#fff;border-radius:8px;outline:none;padding:0 10px}.email-access-form label.is-required-empty input{background:#fef2f2;border-color:#fecaca}.email-access-form input:focus,.email-access-panel select:focus{border-color:var(--blue);box-shadow:0 0 0 3px var(--blue-ring)}.email-access-input.is-valid{background:#f0fdf4;border-color:#16a34a}.email-access-input.is-valid:focus{border-color:#16a34a;box-shadow:0 0 0 3px #16a34a2e}.email-access-input.is-invalid{background:#fef2f2;border-color:#dc2626}.email-access-input.is-invalid:focus{border-color:#dc2626;box-shadow:0 0 0 3px #dc26262e}.email-access-ok,.email-access-error{margin-top:10px;font-size:13px;font-weight:700}.email-access-ok{color:#166534}.email-access-error{color:#991b1b}.email-access-sent-panel{text-align:center;padding:32px 24px}.email-access-sent-icon{margin-bottom:12px;font-size:40px}.email-access-sent-title{color:var(--text);margin:0 0 6px;font-size:20px;font-weight:700}.email-access-sent-address{color:var(--muted);word-break:break-all;margin:0 0 16px;font-size:14px;font-weight:600}.email-access-sent-hint{color:var(--muted);margin:0 0 20px;font-size:13px;line-height:1.5}.email-access-otp-form{flex-direction:column;align-items:center;gap:12px;margin-bottom:20px;display:flex}.email-access-otp-input{letter-spacing:8px;text-align:center;border:2px solid var(--border-strong);width:200px;color:var(--text);background:#fff;border-radius:8px;outline:none;padding:12px 16px;font-size:28px;font-weight:700}.email-access-otp-input::placeholder{color:#0f172a38;font-weight:500}.email-access-otp-input:focus{border-color:var(--blue);box-shadow:0 0 0 3px var(--blue-ring)}.email-access-resend-link{color:var(--muted);cursor:pointer;background:0 0;border:none;padding:0;font-size:13px;text-decoration:underline}.email-access-resend-link:hover{color:var(--text)}.identity-panel label{gap:6px;display:grid}.name-fields-row{grid-column:1/span 2;gap:16px;display:flex}.gela-row{align-items:center;gap:6px;display:flex}.gela-row select{flex:auto;min-width:0}.gela-remove-button{border:1px solid var(--border);background:var(--panel);width:32px;height:32px;color:var(--danger,#dc2626);cursor:pointer;border-radius:6px;flex-shrink:0;justify-content:center;align-items:center;padding:0;display:inline-flex}.gela-remove-button:hover{border-color:var(--danger,#dc2626);background:#dc262614}.gela-remove-button .icon{width:16px;height:16px}.name-fields-row label{flex-direction:column;flex:1;gap:6px;display:flex}.phone-field{grid-area:2/1/auto/span 1}.identity-panel p{text-align:center;margin-top:10px}.identity-panel span{color:var(--muted);font-size:12px;font-weight:700}.identity-panel em{color:#dc2626;font-style:normal}.identity-panel input,.identity-panel select,.identity-panel textarea{border:1px solid var(--border-strong);height:38px;min-height:38px;color:var(--text);background:#fff;border-radius:8px;outline:none;padding:0 10px}.identity-panel input:focus,.identity-panel select:focus,.identity-panel textarea:focus{border-color:var(--blue);box-shadow:0 0 0 3px var(--blue-ring)}.identity-panel label.is-required-empty input,.identity-panel label.is-required-empty select,.identity-panel .identity-check.is-required-empty,.email-access-panel label.is-required-empty input,.email-access-panel label.is-required-empty select,.email-access-panel .identity-check.is-required-empty{background:#fef2f2;border-color:#fecaca}.identity-panel textarea{resize:vertical;height:100%;min-height:38px;padding:8px 10px}.identity-panel .identity-check,.email-access-panel .identity-check{border:1px solid var(--border);background:var(--panel-soft);border-radius:8px;align-items:center;gap:8px;height:38px;min-height:38px;padding:9px 10px;display:flex}.identity-check input{flex:none;width:16px;height:16px;min-height:0;padding:0}.email-access-panel span{color:var(--muted);font-size:12px;font-weight:700}.email-access-panel em{color:#dc2626;font-style:normal}.relation-field{grid-area:3/1/auto/span 1;align-self:start}.class-field{grid-area:3/2/auto/span 1}.identity-actions{justify-content:center;gap:10px;margin-top:14px;display:flex}.save-profile-button,.cancel-profile-button{border-radius:8px;min-width:110px;min-height:38px;padding:0 14px;font-size:13px;font-weight:800}.save-profile-button{color:#fff;background:#16a34a;border:1px solid #16a34a}.save-profile-button:hover{background:#15803d}.cancel-profile-button{color:#fff;background:#dc2626;border:1px solid #dc2626}.cancel-profile-button:hover{background:#b91c1c}.consents-title{color:var(--muted);grid-area:4/1/auto/span 1;align-self:end;margin-top:10px;font-size:12px;font-weight:700}.identity-legal{grid-area:5/1/auto/span 1;position:relative}.dni-field{grid-area:2/2/auto/span 1}.dni-field.is-invalid input{background:#fef2f2;border-color:#dc2626}.dni-format-hint{color:#991b1b;margin-top:4px;font-size:12px;font-weight:600;display:block}.age-field{grid-area:4/1/auto/span 1}.basque-field{grid-area:4/2/auto/span 1}.contact-auth-title{color:var(--muted);grid-area:5/1/auto/span 2;align-self:end;margin-top:10px;font-size:12px;font-weight:700}.identity-contact{grid-area:6/1/auto/span 1}.contact-method-field{grid-area:6/2/auto/span 1;display:block;position:relative}.contact-method-field select{width:100%;height:38px}.contact-method-title{position:absolute;bottom:calc(100% + 14px);left:0}.info-button{border:1px solid var(--border-strong);width:24px;height:24px;color:var(--blue);background:#fff;border-radius:999px;flex:0 0 24px;justify-content:center;align-items:center;margin-left:auto;font-size:13px;font-weight:900;display:inline-flex}.info-button:hover{background:var(--blue-soft)}.read-first-warning{color:#dc2626;white-space:nowrap;margin-left:auto;font-size:12px;font-weight:800}.read-first-warning+.info-button{margin-left:0}.modal-backdrop{z-index:30;background:#0f172a5c;place-items:center;padding:20px;animation:.2s ease-out modal-backdrop-fade-in;display:grid;position:fixed;inset:0}@keyframes modal-backdrop-fade-in{0%{opacity:0}to{opacity:1}}.legal-modal,.login-modal,.member-form-modal{transform-origin:50%;animation:.38s cubic-bezier(.34,1.7,.64,1) modal-boing}@keyframes modal-boing{0%{opacity:0;transform:scale(.4)}60%{opacity:1;transform:scale(1.08)}80%{transform:scale(.96)}to{transform:scale(1)}}.family-member-picker-backdrop .legal-modal,.family-member-picker-backdrop .login-modal,.family-member-picker-backdrop .member-form-modal{animation:none}.legal-modal{border:1px solid var(--border);background:#fff;border-radius:8px;gap:12px;width:min(460px,100%);padding:20px;display:grid;box-shadow:0 24px 60px #0f172a38}.legal-modal h3{margin:0;font-size:20px;line-height:1.2}.login-modal{border:1px solid var(--border);background:#fff;border-radius:8px;gap:12px;width:min(460px,100%);padding:20px;display:grid;position:relative;box-shadow:0 24px 60px #0f172a38}.member-form-modal{border:1px solid var(--border);background:#fff;border-radius:8px;gap:16px;width:min(760px,100%);max-height:calc(100vh - 40px);padding:20px;display:grid;position:relative;overflow-y:auto;box-shadow:0 24px 60px #0f172a38}.lopd-modal-text{border:1px solid var(--border);background:var(--panel-soft);max-height:min(280px,35vh);color:var(--text);border-radius:6px;padding:12px 14px;font-size:13px;line-height:1.5;overflow-y:auto}.lopd-modal-text:focus{outline:2px solid var(--blue);outline-offset:2px}.lopd-modal-text h3{margin:0 0 8px;font-size:14px;font-weight:700}.lopd-modal-text p{margin:0 0 8px}.lopd-modal-text p:last-child{margin-bottom:0}.login-modal-close{width:32px;height:32px;color:var(--muted);cursor:pointer;background:0 0;border:none;border-radius:6px;place-items:center;font-size:24px;line-height:1;transition:background-color .12s,color .12s;display:grid;position:absolute;top:8px;right:8px}.login-modal-close:hover{color:var(--text);background:#0f172a0f}.login-modal-close:focus-visible{outline:2px solid var(--accent,#2563eb);outline-offset:2px}.login-modal-content{gap:12px;display:grid}.login-modal-heading{gap:8px;display:grid}.login-modal-heading h2{margin:0;font-size:22px;line-height:1.2}.login-modal-heading p{color:var(--muted);margin:0;font-size:14px;line-height:1.5}.auth-orphans-content{gap:16px;display:grid}.auth-orphans-totals{grid-template-columns:repeat(3,1fr);gap:12px;display:grid}@media (width<=640px){.auth-orphans-totals{grid-template-columns:1fr}}.auth-orphans-tile{background:var(--surface-soft,#0f172a08);border:1px solid var(--border,#e5e7eb);border-radius:8px;gap:4px;padding:12px;display:grid}.auth-orphans-tile-label{color:var(--muted);text-transform:uppercase;letter-spacing:.5px;font-size:12px}.auth-orphans-tile-value{color:var(--text);font-size:24px;font-weight:700}.auth-orphans-tile-value-small{color:var(--text);font-size:14px;font-weight:600}.auth-orphans-breakdown{gap:8px;display:grid}.auth-orphans-breakdown h4{color:var(--muted);text-transform:uppercase;letter-spacing:.5px;margin:0;font-size:13px;font-weight:700}.auth-orphans-bars{gap:4px;margin:0;padding:0;list-style:none;display:grid}.auth-orphans-bar-row{grid-template-columns:48px 1fr 36px;align-items:center;gap:8px;font-size:13px;display:grid}.auth-orphans-bar-date{color:var(--muted);font-variant-numeric:tabular-nums}.auth-orphans-bar-track{background:#2563eb14;border-radius:4px;height:18px;overflow:hidden}.auth-orphans-bar-fill{background:var(--blue,#2563eb);border-radius:4px;height:100%;transition:width .2s}.auth-orphans-bar-count{text-align:right;font-variant-numeric:tabular-nums;color:var(--text);font-weight:600}.auth-orphans-actions{justify-content:flex-end;margin-top:8px;display:flex}.login-unknown-account{background:#fef2f2;border:1px solid #fecaca;border-radius:8px;gap:12px;padding:16px;display:grid}.login-unknown-account h3{color:#991b1b;margin:0;font-size:16px}.login-unknown-account p{color:var(--text);margin:0;font-size:14px;line-height:1.5}.login-unknown-account-actions{flex-wrap:wrap;gap:8px;display:flex}.login-switch-link{text-align:center;color:var(--muted);margin:4px 0 0;font-size:13px}.login-inline-link{appearance:none;color:var(--accent,#2563eb);cursor:pointer;font-weight:600;font-size:inherit;background:0 0;border:none;padding:0;text-decoration:underline;display:inline}.login-inline-link:hover{color:#1d4ed8}.login-inline-link:focus-visible{outline:2px solid var(--accent,#2563eb);outline-offset:2px;border-radius:2px}.login-lopd-section{background:var(--surface-soft,#0f172a08);border-radius:8px;gap:10px;padding:12px;display:grid}.login-lopd-read-button{appearance:none;border:1px dashed var(--border-strong,#cbd5e1);color:var(--accent,#2563eb);cursor:pointer;text-align:left;background:0 0;border-radius:6px;padding:8px 12px;font-size:13px;font-weight:600}.login-lopd-read-button:hover{border-color:var(--accent,#2563eb);background:#2563eb0f}.login-lopd-read-button:focus-visible{outline:2px solid var(--accent,#2563eb);outline-offset:2px}.login-lopd-check.is-disabled{opacity:.55;cursor:not-allowed}.login-lopd-check.is-disabled input[type=checkbox]{cursor:not-allowed}.login-mode-tabs{background:#0f172a0a;border-radius:8px;grid-template-columns:1fr 1fr;gap:0;padding:4px;display:grid}.login-mode-tab{appearance:none;color:var(--muted);cursor:pointer;background:0 0;border:none;border-radius:6px;padding:8px 12px;font-size:14px;font-weight:600;transition:background-color .12s,color .12s}.login-mode-tab:hover{color:var(--text)}.login-mode-tab.is-active{color:var(--text);background:#fff;box-shadow:0 1px 2px #0f172a14}.login-mode-tab:focus-visible{outline:2px solid var(--accent,#2563eb);outline-offset:2px}.email-access-form .login-lopd-check,.login-lopd-check{cursor:pointer;align-items:flex-start;gap:8px;margin:4px 0 0;display:flex}.email-access-form .login-lopd-check input[type=checkbox],.login-lopd-check input[type=checkbox]{border:1px solid var(--border-strong);cursor:pointer;width:18px;height:18px;min-height:18px;accent-color:var(--blue,#2563eb);background:#fff;border-radius:4px;flex:0 0 18px;margin:2px 0 0;padding:0}.email-access-form .login-lopd-check .login-lopd-check-text,.login-lopd-check .login-lopd-check-text{color:var(--text);text-align:left;font-size:13px;font-weight:500;line-height:1.4}.email-access-form .login-lopd-check em,.login-lopd-check em{color:#dc2626;font-style:normal;font-weight:700}.email-access-hint{color:var(--muted);text-align:center;margin:4px 0 0;font-size:12px}.login-page{place-items:center;min-height:calc(100vh - 176px);padding:24px 0;display:grid}.login-panel{border:1px solid var(--border);background:var(--panel);width:min(420px,100%);box-shadow:var(--shadow);border-radius:8px;gap:14px;padding:22px;display:grid}.login-panel h2,.status-header h2{letter-spacing:0;margin:0;font-size:22px;line-height:1.2}.login-panel label{gap:6px;display:grid}.login-panel span{color:var(--muted);font-size:12px;font-weight:700}.login-panel input{border:1px solid var(--border-strong);min-height:40px;color:var(--text);background:#fff;border-radius:8px;outline:none;padding:0 10px}.login-panel input:focus{border-color:var(--blue);box-shadow:0 0 0 3px var(--blue-ring)}.login-error{color:#991b1b;background:#fef2f2;border:1px solid #fecaca;border-radius:8px;padding:10px 12px;font-size:13px;font-weight:700}.news-form{border-bottom:1px solid var(--border);background:var(--panel-soft);grid-template-columns:minmax(180px,1fr) 180px;gap:12px;padding:16px;display:grid}.news-form label{gap:6px;display:grid}.news-form span{color:var(--muted);font-size:12px;font-weight:700}.news-form input,.news-form textarea{border:1px solid var(--border-strong);min-height:38px;color:var(--text);background:#fff;border-radius:8px;outline:none;padding:0 10px}.news-form textarea{resize:vertical;min-height:110px;padding:8px 10px}.news-form input:focus,.news-form textarea:focus{border-color:var(--blue);box-shadow:0 0 0 3px var(--blue-ring)}.news-body-field,.news-form-actions{grid-column:1/-1}.news-form-actions{justify-content:flex-end;gap:8px;display:flex}.ikastola-info-form{grid-template-columns:1fr 1fr 1fr;align-items:end;gap:12px;padding:16px;display:grid}.ikastola-info-form label,.ikastola-info-form>div:not(.ikastola-info-actions){gap:6px;display:grid}.ikastola-info-form span{color:var(--muted);text-transform:uppercase;font-size:12px;font-weight:700}.ikastola-info-form p{margin:0;font-size:14px}.ikastola-info-form input{border:1px solid var(--border-strong);border-radius:8px;outline:none;min-height:38px;padding:0 10px;font-size:14px}.ikastola-info-form input:focus{border-color:var(--blue);box-shadow:0 0 0 3px var(--blue-ring)}.ikastola-info-actions{flex-direction:row;grid-column:1/-1;justify-content:center;gap:8px;display:flex}.toast-notification{z-index:60;border:1px solid;border-radius:8px;align-items:center;gap:12px;width:min(560px,100vw - 32px);padding:12px 14px;font-size:13px;font-weight:700;display:flex;position:fixed;top:16px;left:50%;transform:translate(-50%);box-shadow:0 24px 60px #0f172a38}.toast-notification.is-success{color:#166534;background:#f0fdf4;border-color:#bbf7d0}.toast-notification.is-error{color:#991b1b;background:#fef2f2;border-color:#fecaca}.toast-close{width:28px;height:28px;color:inherit;background:0 0;border:1px solid;border-radius:8px;flex:0 0 28px;justify-content:center;align-items:center;margin-left:auto;font-size:12px;font-weight:800;display:inline-flex}.toast-close:hover{background:#ffffff73}.screen-blocker{z-index:30;background:0 0;position:fixed;inset:0}.loading-overlay{z-index:80;background:#0f172a73;place-items:center;padding:20px;animation:.16s ease-out loading-overlay-fade-in;display:grid;position:fixed;inset:0}@keyframes loading-overlay-fade-in{0%{opacity:0}to{opacity:1}}.loading-overlay-card{text-align:center;background:#fff;border-radius:12px;justify-items:center;gap:14px;min-width:200px;max-width:min(360px,100%);padding:22px 26px;display:grid;box-shadow:0 24px 60px #0f172a47}.loading-overlay-message{color:#1f2937;margin:0;font-size:14px;font-weight:600}.loading-spinner{border:3px solid #e2e8f0;border-top-color:#2563eb;border-radius:50%;width:36px;height:36px;animation:.72s linear infinite loading-spinner-rotate}@keyframes loading-spinner-rotate{to{transform:rotate(360deg)}}.primary-button{border-color:var(--blue);background:var(--blue);color:#fff}.danger-button{color:#991b1b;border-color:#fecaca}.danger-button:hover{background:#fef2f2;border-color:#f87171}.gela-selector-modal{width:min(760px,100%)}.gela-selector-groups{gap:14px;width:100%;margin:8px 0 4px;display:grid}.gela-group{gap:8px;display:grid}.gela-group h4{margin:0;font-size:14px}.gela-group-grid{grid-template-columns:repeat(auto-fit,minmax(80px,1fr));gap:8px;display:grid}.gela-chip{border:1px solid var(--border);min-height:34px;color:var(--text);white-space:nowrap;background:#fff;border-radius:8px;justify-content:center;align-items:center;padding:0 10px;font-size:13px;font-weight:650;display:inline-flex}.gela-chip:hover{border-color:var(--blue);background:var(--blue-soft)}.gela-chip.is-active{border-color:var(--blue);background:var(--blue-soft);color:var(--blue)}.time-inputs{grid-template-columns:1fr auto 1fr;align-items:center;gap:6px;min-width:0;display:grid}.signup-button{color:#fff;background:#16a34a;border:1px solid #16a34a;border-radius:8px;min-height:38px;padding:0 14px;font-size:13px;font-weight:800}.signup-button:hover{background:#15803d}.signup-button.is-cancel{background:#dc2626;border-color:#dc2626}.signup-button.is-cancel:hover{background:#b91c1c}.signup-button:disabled{opacity:.5}.signup-confirm-modal{text-align:center;justify-items:center;width:min(520px,100%)}.signup-confirm-modal p{margin-top:0}.signup-confirm-modal input[type=text]{border:1px solid var(--border-strong);width:100%;color:var(--text);background:#fff;border-radius:8px;outline:none;padding:8px 10px}.signup-confirm-modal input[type=text]:focus{border-color:var(--blue);box-shadow:0 0 0 3px var(--blue-ring)}.prompt-modal-error{color:#b91c1c;text-align:left;width:100%;margin:0;font-size:13px}.signup-note-field{text-align:left;gap:6px;width:100%;display:grid}.signup-note-field span{color:var(--muted);font-size:12px;font-weight:700}.signup-note-field textarea{border:1px solid var(--border-strong);min-height:96px;color:var(--text);resize:vertical;background:#fff;border-radius:8px;outline:none;padding:8px 10px}.signup-note-field textarea:focus{border-color:var(--blue);box-shadow:0 0 0 3px var(--blue-ring)}.signup-gela-field{text-align:left;gap:6px;width:100%;display:grid}.signup-gela-field>span{color:var(--text);font-size:13px;font-weight:700}.signup-gela-field>span em{color:#b91c1c;margin-left:2px;font-style:normal;font-weight:800}.signup-gela-field select{border:1px solid var(--border-strong);width:100%;height:40px;min-height:40px;color:var(--text);background:#fff;border-radius:8px;outline:none;padding:0 10px}.signup-gela-field select:focus{border-color:var(--blue);box-shadow:0 0 0 3px var(--blue-ring)}.signup-gela-info{background:var(--blue-soft);width:100%;color:var(--text);text-align:left;border-radius:8px;margin:0;padding:8px 12px;font-size:13px}.signup-gela-info strong{color:var(--blue)}.signup-confirm-actions{grid-template-columns:repeat(2,minmax(120px,1fr));gap:8px;width:100%;display:grid}.signup-confirm-actions button{justify-content:center;width:100%}.signup-confirm-actions-single{grid-template-columns:minmax(120px,1fr);justify-content:center}.panel-subtitle{color:var(--muted);margin:4px 0 0;font-size:13px;line-height:1.4}.email-settings-state{border:1px solid var(--border,#e5e7eb);border-radius:8px;margin-bottom:16px;padding:14px 16px}.email-settings-state.is-active{background:#f0fdf4;border-color:#bbf7d0}.email-settings-state.is-blocked{background:#fef2f2;border-color:#fecaca}.email-settings-state-line strong{margin-right:4px}.email-settings-hint{color:var(--muted);margin:8px 0 0;font-size:13px}.email-settings-actions{margin:16px 0}.primary-button.is-danger{background:#dc2626;border-color:#dc2626}.primary-button.is-danger:hover:not(:disabled){background:#b91c1c;border-color:#b91c1c}.email-settings-details{background:var(--surface-soft,#0f172a08);border-radius:6px;margin-top:12px;padding:8px 12px;font-size:13px}.email-settings-details summary{cursor:pointer;font-weight:600}.email-settings-details ul{color:var(--muted);margin:8px 0 0;padding-left:20px}.email-settings-details li{margin:4px 0}.legal-texts-form{gap:16px;display:grid}.legal-texts-grid{grid-template-columns:1fr 1fr;gap:16px;display:grid}.legal-texts-field{gap:6px;display:grid}.legal-texts-field>span{color:var(--muted);font-size:12px;font-weight:700}.legal-texts-field em{color:#dc2626;font-style:normal}.legal-texts-field input,.legal-texts-field textarea{border:1px solid var(--border-strong);color:var(--text);font:inherit;background:#fff;border-radius:8px;outline:none;padding:8px 10px}.legal-texts-field textarea{resize:vertical;min-height:200px;line-height:1.5}.legal-texts-field input:focus,.legal-texts-field textarea:focus{border-color:var(--blue);box-shadow:0 0 0 3px var(--blue-ring)}.legal-texts-hint{color:var(--muted);font-size:11px}.legal-texts-actions{align-items:center;gap:12px;display:flex}.legal-texts-warning{color:#92400e;background:#fffbeb;border-left:3px solid #f59e0b;border-radius:4px;margin:0;padding:10px 12px;font-size:12px;line-height:1.4}@media (width<=640px){.legal-texts-grid{grid-template-columns:1fr}}
