:root{--color-primary: #0f7a5a;--color-primary-light: #18b29a;--color-primary-dark: #0b5b43;--color-secondary: #e7f2ee;--gradient-primary: linear-gradient(135deg, #0f7a5a 0%, #18b29a 100%);--gradient-surface: linear-gradient(180deg, #ffffff 0%, #f7fbf9 100%);--color-success: #1a8f6b;--color-success-light: #20ad83;--color-error: #9a3f38;--color-error-light: #d45a51;--color-warning: #f1b746;--color-warning-light: #ffd773;--color-info: #178fce;--color-selected: #0f7a5a;--color-selected-text: #ffffff;--color-text: #1d2f2a;--color-text-light: #47665d;--color-text-muted: #6f8a81;--color-background: #f3f7f4;--color-surface: #ffffff;--color-border: #d3e3dc;--color-border-light: #e2efea;--space-xs: .25rem;--space-sm: .5rem;--space-md: 1rem;--space-lg: 1.5rem;--space-xl: 2rem;--space-2xl: 3rem;--space-3xl: 4rem;--font-size-xs: clamp(.75rem, .7rem + .25vw, .875rem);--font-size-sm: clamp(.875rem, .8rem + .3vw, 1rem);--font-size-base: clamp(.9375rem, .875rem + .3vw, 1.125rem);--font-size-lg: clamp(1.125rem, 1rem + .5vw, 1.25rem);--font-size-xl: clamp(1.25rem, 1.125rem + .625vw, 1.5rem);--font-size-2xl: clamp(1.5rem, 1.25rem + 1vw, 2rem);--font-size-3xl: clamp(1.875rem, 1.5rem + 1.5vw, 2.5rem);--font-weight-normal: 400;--font-weight-medium: 500;--font-weight-semibold: 600;--font-weight-bold: 700;--line-height-tight: 1.25;--line-height-normal: 1.5;--line-height-relaxed: 1.75;--radius-sm: .4rem;--radius-md: .75rem;--radius-lg: 1rem;--radius-xl: 1.25rem;--radius-full: 9999px;--shadow-sm: 0 1px 2px rgb(15 122 90 / .08);--shadow-base: 0 3px 10px rgb(15 122 90 / .08);--shadow-md: 0 8px 20px rgb(15 122 90 / .1);--shadow-lg: 0 12px 30px rgb(15 122 90 / .12);--shadow-xl: 0 18px 40px rgb(15 122 90 / .14);--transition-fast: .15s ease;--transition-base: .25s ease;--transition-slow: .35s ease;--z-base: 1;--z-dropdown: 100;--z-sticky: 200;--z-fixed: 300;--z-overlay: 900;--z-modal: 1000;--z-toast: 1100;--container-sm: 600px;--container-md: 768px;--container-lg: 1024px;--container-xl: 1280px;--touch-target-min: 44px;--safe-area-top: env(safe-area-inset-top, 0px);--safe-area-bottom: env(safe-area-inset-bottom, 0px);--safe-area-left: env(safe-area-inset-left, 0px);--safe-area-right: env(safe-area-inset-right, 0px)}*,*:before,*:after{box-sizing:border-box}*{margin:0;padding:0}html{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-size-adjust:100%;block-size:100%;scroll-behavior:smooth}@media(prefers-reduced-motion:reduce){*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important;scroll-behavior:auto!important}}body{min-block-size:100%;font-family:system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif;font-size:var(--font-size-base);line-height:var(--line-height-normal);color:var(--color-text);background-color:var(--color-background);background-image:radial-gradient(circle at 18% 20%,#f1f7f3,#f7fbf9 35%,#f3f7f4);position:relative;overflow-x:hidden;word-wrap:break-word;overflow-wrap:break-word}#app{position:relative;z-index:var(--z-base);inline-size:100%;max-inline-size:100vw;margin-block-start:var(--space-sm);padding-inline:var(--space-md);overflow-x:hidden}h1,h2,h3,h4,h5,h6{color:var(--color-primary);font-weight:var(--font-weight-bold);line-height:var(--line-height-tight);margin-block-end:var(--space-md)}h1{font-size:var(--font-size-3xl);text-align:center;margin-block:var(--space-lg);margin:auto;max-width:90vw}h2{font-size:var(--font-size-2xl);text-align:center;margin-block:var(--space-md)}h3{font-size:var(--font-size-xl);margin-block:var(--space-md) var(--space-sm)}h4{font-size:var(--font-size-lg)}p{margin-block-end:var(--space-md)}a{color:var(--color-primary);text-decoration:none;transition:color var(--transition-fast)}a:hover,a:focus-visible{color:var(--color-primary-dark);text-decoration:underline}.phone-link{color:var(--color-info);text-decoration:underline;transition:color var(--transition-fast);cursor:pointer}.phone-link:hover,.phone-link:focus-visible{color:var(--color-primary-dark);text-decoration:underline}.container{inline-size:100%;max-inline-size:var(--container-lg);margin-inline:auto;padding-inline:var(--space-md)}.container--sm{max-inline-size:var(--container-sm)}.container--md{max-inline-size:var(--container-md)}.surface{background-color:var(--color-surface);border-radius:var(--radius-md);padding:var(--space-md);margin-block-end:var(--space-md);box-shadow:var(--shadow-base);word-break:break-word;overflow-wrap:break-word}.flex{display:flex}.flex-column{display:flex;flex-direction:column}.flex-wrap{flex-wrap:wrap}.items-center{align-items:center}.justify-between{justify-content:space-between}.justify-center{justify-content:center}.gap-sm{gap:var(--space-sm)}.gap-md{gap:var(--space-md)}.gap-lg{gap:var(--space-lg)}.grid{display:grid;gap:var(--space-md)}.grid-2{grid-template-columns:repeat(2,1fr)}.grid-auto-fit{grid-template-columns:repeat(auto-fit,minmax(min(100%,250px),1fr))}.summary-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(min(100%,280px),1fr));gap:var(--space-md);margin-block-end:var(--space-md)}.summary-tile{background-color:var(--color-surface);background-image:var(--gradient-surface);border-radius:var(--radius-md);padding:var(--space-md);box-shadow:var(--shadow-base);border:1px solid var(--color-border-light)}.summary-label{font-weight:var(--font-weight-semibold);color:var(--color-primary);margin-block-end:var(--space-sm);font-size:var(--font-size-lg)}.summary-list{list-style:none;padding:0;margin:0}.summary-list li{padding:var(--space-xs) 0;border-bottom:1px solid var(--color-border-light);font-size:var(--font-size-base)}.summary-list li:last-child{border-bottom:none}.summary-list strong{color:var(--color-primary-dark);font-weight:var(--font-weight-bold)}button,input[type=submit],.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-sm);padding:var(--space-md) var(--space-xl);font-size:var(--font-size-base);font-weight:var(--font-weight-medium);line-height:1;text-align:center;text-decoration:none;border:1px solid transparent;border-radius:var(--radius-lg);cursor:pointer;transition:all var(--transition-base);min-inline-size:var(--touch-target-min);min-block-size:var(--touch-target-min);user-select:none;box-shadow:var(--shadow-sm)}.btn--primary,button,input[type=submit]{background-color:var(--color-primary);background-image:var(--gradient-primary);color:#fff;box-shadow:var(--shadow-md)}.btn--primary:hover:not(:disabled),button:hover:not(:disabled),input[type=submit]:hover:not(:disabled){background-color:var(--color-primary-dark);background-image:linear-gradient(135deg,#0b5b43,#129f87);transform:translateY(-1px) scale(1.01);box-shadow:var(--shadow-lg)}.btn--secondary{background-color:var(--color-surface);color:var(--color-text);border-color:var(--color-border)}.btn--secondary:hover:not(:disabled){background-color:var(--color-secondary);border-color:var(--color-primary-light);color:var(--color-primary-dark);box-shadow:var(--shadow-md)}.btn--success{background-color:var(--color-success);color:#fff}.btn--success:hover:not(:disabled){background-color:var(--color-success-light)}.btn--error{background-color:var(--color-error);color:#fff}.btn--error:hover:not(:disabled){background-color:var(--color-error-light)}.btn--warning{background-color:var(--color-warning);color:#fff}.btn--full{inline-size:100%}button:disabled,.btn:disabled,[disabled]{opacity:.5;cursor:not-allowed;transform:none!important}form{background-color:var(--color-surface);background-image:var(--gradient-surface);border-radius:var(--radius-md);padding:var(--space-lg);margin-block-end:var(--space-lg);box-shadow:var(--shadow-base);border:1px solid var(--color-border-light)}.form-group{margin-block-end:var(--space-lg);display:flex;flex-direction:column;gap:var(--space-sm)}label{display:block;font-weight:var(--font-weight-medium);margin-block-end:var(--space-xs);color:var(--color-text)}input[type=checkbox]:checked~label{color:var(--color-secondary)}input[type=text],input[type=email],input[type=password],input[type=tel],input[type=date],select,textarea{inline-size:100%;padding:var(--space-md);font-size:var(--font-size-base);font-family:inherit;line-height:var(--line-height-normal);color:var(--color-text);background-color:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-sm);transition:all var(--transition-fast)}input:focus,select:focus,textarea:focus{outline:2px solid var(--color-primary);outline-offset:2px;border-color:var(--color-primary)}textarea{min-block-size:100px;resize:vertical}.checkbox-group{display:flex;align-items:center;gap:var(--space-sm)}input[type=checkbox],input[type=radio]{inline-size:var(--space-md);block-size:var(--space-md);cursor:pointer}.language-toggle{position:fixed;inset-block-start:var(--safe-area-top, 10px);inset-inline-end:0;z-index:var(--z-modal);display:flex;flex-direction:column;background-image:var(--gradient-surface);border-start-start-radius:var(--radius-lg);border-end-start-radius:var(--radius-lg);box-shadow:var(--shadow-md);border:1px solid var(--color-border-light);overflow:hidden;transition:inline-size var(--transition-base);inline-size:48px;backdrop-filter:blur(8px)}.language-toggle:hover,.language-toggle:focus-within{inline-size:auto}.lang-btn{display:none;background-color:var(--color-surface);border:none;border-block-end:1px solid var(--color-border-light);color:var(--color-text);padding:var(--space-md);cursor:pointer;font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);text-align:center;transition:all var(--transition-base);min-inline-size:48px;min-block-size:var(--touch-target-min)}.lang-btn:last-child{border-block-end:none}.lang-btn.active{display:flex;align-items:center;justify-content:center;background-image:var(--gradient-primary);color:#fff}.language-toggle:hover .lang-btn,.language-toggle:focus-within .lang-btn{display:flex;align-items:center;justify-content:center}.lang-btn:hover:not(.active){background-color:var(--color-secondary)}.lang-btn.active:hover{background-image:linear-gradient(135deg,#0b5b43,#129f87)}.home-icon{position:fixed;inset-block-start:var(--safe-area-top, 10px);inset-inline-start:10px;z-index:var(--z-modal);background-image:var(--gradient-surface);border-radius:var(--radius-lg);box-shadow:var(--shadow-md);padding:var(--space-sm) var(--space-md);color:var(--color-primary);font-size:24px;min-inline-size:var(--touch-target-min);min-block-size:var(--touch-target-min);display:flex;align-items:center;justify-content:center;transition:all var(--transition-base);backdrop-filter:blur(8px)}.home-icon:hover{background-color:var(--color-primary);color:#fff;transform:scale(1.05);text-decoration:none}.settings-icon{position:fixed;inset-block-start:var(--safe-area-top, 10px);inset-inline-end:10px;z-index:var(--z-modal);background-image:var(--gradient-surface);border-radius:var(--radius-lg);box-shadow:var(--shadow-md);padding:var(--space-sm) var(--space-md);color:var(--color-primary);font-size:24px;min-inline-size:var(--touch-target-min);min-block-size:var(--touch-target-min);display:flex;align-items:center;justify-content:center;transition:all var(--transition-base);backdrop-filter:blur(8px);text-decoration:none}.settings-icon:hover{background-color:var(--color-primary);color:#fff;transform:scale(1.05);text-decoration:none}.dashboard-menu{list-style-type:none;padding:0;display:grid;gap:var(--space-md)}.dashboard-menu li{margin:0}.dashboard-button{display:flex;align-items:center;justify-content:center;inline-size:100%;padding:var(--space-lg);background-image:var(--gradient-primary);color:#fff;text-align:center;font-size:var(--font-size-lg);font-weight:var(--font-weight-medium);border-radius:var(--radius-lg);transition:all var(--transition-base);box-shadow:var(--shadow-md);border:none;cursor:pointer;text-decoration:none}.dashboard-button:hover{background-image:linear-gradient(135deg,#0b5b43,#129f87);transform:translateY(-2px);box-shadow:var(--shadow-lg);text-decoration:none}.dashboard-button--primary{background-image:var(--gradient-primary)}.dashboard-button--primary:hover{background-image:linear-gradient(135deg,#0b5b43,#129f87)}.dashboard-button--secondary{background-color:var(--color-surface);color:var(--color-text);border:1px solid var(--color-border);box-shadow:var(--shadow-sm)}.dashboard-button--secondary:hover{background-color:var(--color-secondary);border-color:var(--color-primary-light);color:var(--color-primary-dark)}.dashboard-button--logout{background-color:var(--color-error)}.dashboard-button--logout:hover{background-color:var(--color-error-light)}.logout-button{background-color:var(--color-error)}.logout-button:hover{background-color:var(--color-error-light)}.list-item{display:flex;justify-content:space-between;align-items:center;padding:var(--space-sm);border-block-end:1px solid var(--color-border);cursor:pointer;transition:background-color var(--transition-fast);word-break:break-word;overflow-wrap:break-word;gap:var(--space-md)}.list-item:nth-of-type(2n){background-color:var(--color-secondary)}.list-item:hover{background-color:var(--color-primary-light);color:#fff}.list-item.selected{background-color:var(--color-selected);color:var(--color-selected-text);font-weight:var(--font-weight-semibold)}.list-item .participant-name{flex:1;min-inline-size:0;font-weight:var(--font-weight-medium)}.list-item .participant-points{flex-shrink:0;font-weight:var(--font-weight-bold);min-inline-size:3rem;text-align:end;color:var(--color-primary);font-size:var(--font-size-lg)}.list-item.selected .participant-points{color:var(--color-selected-text)}.group{background-color:var(--color-surface);border-radius:var(--radius-md);padding:0;margin-block-end:var(--space-lg);box-shadow:var(--shadow-base);overflow:hidden}.group-header{background:linear-gradient(135deg,var(--color-border-light) 0%,#d5d5d5 100%);font-weight:var(--font-weight-bold);padding:var(--space-lg);cursor:pointer;display:flex;justify-content:space-between;align-items:center;transition:all var(--transition-base);user-select:none}.group-header:hover{background:linear-gradient(135deg,#d5d5d5,#c5c5c5)}.group-header.selected{background:linear-gradient(135deg,var(--color-primary-light) 0%,var(--color-primary) 100%);color:#fff}.group-content{max-block-size:5000px;overflow:hidden;transition:max-block-size var(--transition-slow);padding:var(--space-md)}.group-content.collapsed{max-block-size:0;padding:0}table{inline-size:100%;border-collapse:collapse;background-color:var(--color-surface);border-radius:var(--radius-md);padding:var(--space-md);margin-block-end:var(--space-md);box-shadow:var(--shadow-base);overflow:hidden}th,td{padding:var(--space-md);text-align:start;border-block-end:1px solid var(--color-border)}th{background-color:var(--color-secondary);font-weight:var(--font-weight-semibold);color:var(--color-text)}tr:hover{background-color:#18b29a14}@media(width<=600px){table,thead,tbody,th,td{display:block}thead tr{position:absolute;inset-block-start:-9999px;inset-inline-start:-9999px}tr{margin-block-end:var(--space-lg);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:var(--space-md);display:flex;flex-wrap:wrap}td{border:none;position:relative;text-align:end}td:before{content:attr(data-label);position:absolute;inset-inline-start:var(--space-md);inset-block-start:var(--space-md);inline-size:45%;padding-inline-end:var(--space-sm);white-space:nowrap;font-weight:var(--font-weight-semibold);text-align:start}}@media(width>=601px){td:before{content:none}}.participant-item,.participant-card{background-color:var(--color-surface);background-image:var(--gradient-surface);border:1px solid var(--color-border-light);border-radius:var(--radius-lg);padding:var(--space-lg);box-shadow:var(--shadow-md);display:flex;flex-direction:column;gap:var(--space-md);word-break:break-word;overflow-wrap:break-word;transition:box-shadow var(--transition-fast)}.participant-card:hover{box-shadow:var(--shadow-lg)}.participant-card__header{display:flex;justify-content:space-between;align-items:center;gap:var(--space-md);padding-block-end:var(--space-sm);border-block-end:2px solid var(--color-border-light)}.participant-card__name{font-weight:var(--font-weight-bold);font-size:var(--font-size-lg);margin:0;color:var(--color-primary);flex:1;min-inline-size:0}.participant-card__edit-btn{padding:var(--space-sm) var(--space-md);background-color:var(--color-primary);color:#fff;border-radius:var(--radius-md);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);text-decoration:none;transition:all var(--transition-fast);white-space:nowrap;flex-shrink:0}.participant-card__edit-btn:hover{background-color:var(--color-primary-dark);transform:translateY(-1px);box-shadow:var(--shadow-sm)}.participant-card__statement{display:flex;flex-direction:column;gap:var(--space-xs);padding:var(--space-md);background:linear-gradient(135deg,var(--color-warning) 0%,var(--color-warning-light) 100%);color:#fff;border:none;border-radius:var(--radius-md);font-weight:var(--font-weight-semibold);cursor:pointer;transition:all var(--transition-fast);text-align:start;box-shadow:var(--shadow-sm)}.participant-card__statement:hover{transform:translateY(-2px);box-shadow:var(--shadow-md)}.participant-card__statement-label{font-size:var(--font-size-sm);opacity:.95}.participant-card__statement-amount{font-size:var(--font-size-lg);font-weight:var(--font-weight-bold)}.participant-card__forms{display:grid;grid-template-columns:1fr;gap:var(--space-sm)}.form-btn{display:flex;align-items:center;gap:var(--space-sm);padding:var(--space-sm) var(--space-md);background-color:var(--color-secondary);border:2px solid var(--color-border);border-radius:var(--radius-md);text-decoration:none;transition:all var(--transition-fast);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--color-text)}.form-btn:hover{transform:translateY(-1px);box-shadow:var(--shadow-sm);text-decoration:none}.form-btn__icon{font-size:var(--font-size-lg);flex-shrink:0}.form-btn__label{flex:1;min-inline-size:0}.form-btn--completed{background-color:var(--color-success-light);border-color:var(--color-success);color:#fff}.form-btn--completed:hover{background-color:var(--color-success)}.form-btn--incomplete{background-color:var(--color-secondary);border-color:var(--color-border)}.form-btn--incomplete:hover{border-color:var(--color-primary);background-color:var(--color-primary-light)}.form-btn--badge{background:linear-gradient(135deg,gold,#ffed4e);border-color:gold;color:#000;font-weight:var(--font-weight-semibold)}.form-btn--badge:hover{background:linear-gradient(135deg,#ffed4e,gold)}.participant-name{font-weight:var(--font-weight-bold);margin-block-end:var(--space-sm);font-size:var(--font-size-lg)}.participant-actions{display:flex;flex-wrap:wrap;gap:var(--space-sm);margin-block-start:var(--space-md)}.participant-actions a{flex:1;padding:var(--space-sm) var(--space-md);text-align:center;background-color:var(--color-success);color:#fff;border-radius:var(--radius-sm);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);transition:all var(--transition-fast)}.participant-actions a:hover{background-color:var(--color-success-light);transform:translateY(-1px);text-decoration:none}.badge{display:inline-flex;align-items:center;justify-content:center;padding:var(--space-xs) var(--space-sm);font-size:var(--font-size-xs);font-weight:var(--font-weight-bold);border-radius:var(--radius-sm);line-height:1}.badge--leader{background-color:gold;color:#000}.badge--second-leader{background-color:silver;color:#000}.participant-status{padding:var(--space-xs) var(--space-sm);border-radius:var(--radius-sm);font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);margin-inline-start:var(--space-md);display:inline-block}.participant-status.present{background-color:var(--color-success-light);color:#fff}.participant-status.present.gray{background-color:#7d7d7d;color:#fff}.participant-status.absent{background-color:var(--color-error-light);color:#fff}.participant-status.late{background-color:var(--color-warning-light);color:#000}.participant-status.excused{background-color:var(--color-info);color:#fff}.fixed-bottom,.status-buttons{position:fixed;inset-block-end:0;inset-inline:0;background-color:#f8f8f8f2;backdrop-filter:blur(10px);padding:var(--space-md);padding-block-end:calc(var(--space-md) + var(--safe-area-bottom));display:grid;grid-template-columns:repeat(auto-fit,minmax(40px,1fr));gap:var(--space-sm);box-shadow:0 -4px 12px #0000001a;z-index:var(--z-fixed)}.point-btn,.status-button{padding:var(--space-lg);border:none;border-radius:var(--radius-md);font-size:var(--font-size-base);font-weight:var(--font-weight-semibold);cursor:pointer;min-inline-size:var(--touch-target-min);min-block-size:var(--touch-target-min);transition:all var(--transition-base);box-shadow:var(--shadow-sm)}.point-btn:hover,.status-button:hover{transform:translateY(-2px);box-shadow:var(--shadow-md)}.point-btn.add,.status-button[data-status=present],.status-button[data-status=motivated]{background-color:var(--color-success);color:#fff}.point-btn.remove,.status-button[data-status=non-motivated]{background-color:var(--color-error);color:#fff}.status-button[data-status=late]{background-color:var(--color-warning);color:#fff}.attendance-list,#points-list,#honors-list{margin-block-end:calc(7rem + var(--safe-area-bottom));padding-block-end:var(--space-md)}.dashboard-card{background-color:var(--color-surface);border-radius:var(--radius-md);padding:var(--space-md);margin:var(--space-md);box-shadow:var(--shadow-sm)}.section-header{display:flex;align-items:center;justify-content:space-between;gap:var(--space-sm);flex-wrap:wrap;margin-block-end:var(--space-sm)}.section-header h3{margin:0;font-size:var(--font-size-lg)}.section-actions{display:flex;align-items:center;gap:var(--space-sm);flex-wrap:wrap}.ghost-button{border:1px solid var(--color-border);background-color:transparent;color:var(--color-text-primary);padding:var(--space-sm) var(--space-md);border-radius:var(--radius-md);font-weight:var(--font-weight-medium);min-inline-size:var(--touch-target-min);min-block-size:var(--touch-target-min);user-select:none;-webkit-user-select:none;touch-action:manipulation;-webkit-tap-highlight-color:transparent;cursor:pointer}.ghost-button:disabled{opacity:.6}.text-link{color:var(--color-primary);font-weight:var(--font-weight-medium);text-decoration:underline}#points-list.collapsed{padding:var(--space-sm) 0}.muted-text{color:var(--color-text-secondary);margin:0}.error-text{color:var(--color-error);margin:0}.news-list{list-style:none;padding:0;margin:0;display:grid;gap:var(--space-sm)}.news-item{border:1px solid var(--color-border);border-radius:var(--radius-md);padding:var(--space-md);display:grid;gap:var(--space-xs);background-color:var(--color-secondary)}.news-item-header{display:flex;justify-content:space-between;gap:var(--space-sm);align-items:baseline;flex-wrap:wrap}.news-title{font-weight:var(--font-weight-semibold);margin:0}.news-date{color:var(--color-text-secondary);font-size:var(--font-size-sm)}.news-summary{margin:0;color:var(--color-text-primary);line-height:1.5}.name-item,.participant-row{display:flex;justify-content:space-between;align-items:center;padding:var(--space-lg);border-block-end:1px solid var(--color-border);cursor:pointer;transition:all var(--transition-fast);word-break:break-word;overflow-wrap:break-word}.name-item:nth-child(2n),.participant-row:nth-child(2n){background-color:var(--color-secondary)}.name-item:hover,.participant-row:hover{background-color:var(--color-primary-light);color:#fff}.name-item.selected,.participant-row.selected{background-color:var(--color-selected);color:var(--color-selected-text);font-weight:var(--font-weight-bold)}.date-navigation{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:var(--space-md);margin-block-end:var(--space-lg);padding:var(--space-md);background-color:var(--color-surface);border-radius:var(--radius-md);box-shadow:var(--shadow-base)}.date-navigation button,.nav-btn{background-color:var(--color-primary);color:#fff;border:none;padding:var(--space-sm) var(--space-lg);border-radius:var(--radius-md);cursor:pointer;font-size:var(--font-size-base);font-weight:var(--font-weight-medium);transition:all var(--transition-fast)}.date-navigation button:hover{background-color:var(--color-primary-dark)}#currentDate{text-align:center;font-weight:var(--font-weight-bold);font-size:var(--font-size-xl);color:var(--color-primary)}.modal{display:none;position:fixed;z-index:var(--z-modal);inset:0;background-color:#00000080;backdrop-filter:blur(4px);animation:fadeIn var(--transition-base)}.modal-content{background-color:var(--color-surface);margin:15% auto;padding:var(--space-2xl);border-radius:var(--radius-lg);box-shadow:var(--shadow-xl);inline-size:90%;max-inline-size:600px;animation:slideUp var(--transition-base)}.close{margin-top:calc(var(--space-lg) + var(--space-lg));color:var(--color-text-muted);float:inline-end;font-size:28px;font-weight:var(--font-weight-bold);cursor:pointer;border:none;background:none;transition:color var(--transition-fast)}.close:hover,.close:focus{color:var(--color-primary)}.modal-overlay{display:flex;position:fixed;align-items:center;justify-content:center;inset:0;z-index:var(--z-modal);background-color:#00000080;backdrop-filter:blur(4px);padding:var(--space-md);padding-block-start:calc(var(--space-md) + var(--safe-area-top));padding-block-end:calc(var(--space-md) + var(--safe-area-bottom));overflow-y:auto;animation:fadeIn var(--transition-base)}.modal.show,.modal-overlay.show{display:flex}.modal-overlay .modal-content{display:flex;flex-direction:column;margin:auto;inline-size:100%;max-inline-size:600px;max-block-size:90vh;background-color:var(--color-surface);border-radius:var(--radius-lg);box-shadow:var(--shadow-xl);animation:slideUp var(--transition-base);overflow:hidden}.modal-content.modal-large{max-inline-size:900px}.modal-header{display:flex;align-items:center;justify-content:space-between;gap:var(--space-md);padding:var(--space-lg);padding-block-end:var(--space-md);border-block-end:1px solid var(--color-border);flex-shrink:0}.modal-header h3,.modal-header h2,.modal-header h4{margin:0;color:var(--color-text);font-size:var(--font-size-xl);flex:1}.modal-body{flex:1;padding:var(--space-lg);overflow-y:auto;overflow-x:hidden}.modal-footer{display:flex;align-items:center;justify-content:flex-end;gap:var(--space-md);flex-wrap:wrap;padding:var(--space-md) var(--space-lg) var(--space-lg);border-block-start:1px solid var(--color-border);flex-shrink:0}.modal-body .form-actions{display:flex;justify-content:flex-end;gap:var(--space-md);margin-block-start:var(--space-xl);padding-block-start:var(--space-md);border-block-start:1px solid var(--color-border-light);flex-wrap:wrap}.modal-close{background:none;border:none;padding:var(--space-xs);color:var(--color-text-muted);font-size:28px;font-weight:var(--font-weight-bold);line-height:1;cursor:pointer;transition:all var(--transition-fast);min-inline-size:var(--touch-target-min);min-block-size:var(--touch-target-min);display:flex;align-items:center;justify-content:center;flex-shrink:0;border-radius:var(--radius-md)}.modal-close:hover,.modal-close:focus-visible{color:var(--color-primary);background-color:#0000000d}@media(width<=768px){.modal-overlay{padding:var(--space-sm)}.modal-overlay .modal-content{max-inline-size:100%;max-block-size:95vh}.modal-content.modal-large{max-inline-size:100%}.modal-header,.modal-body,.modal-footer{padding-inline:var(--space-md)}.modal-body .form-actions{flex-direction:column}.modal-body .form-actions button{inline-size:100%}}@media(width<=480px){.modal-header h3,.modal-header h2{font-size:var(--font-size-lg)}.modal-close{font-size:24px}}@media(prefers-reduced-motion:reduce){.modal,.modal-overlay,.modal-content{animation:none}}#toast-container{position:fixed;inset-block-start:0;inset-inline:0;z-index:var(--z-toast);pointer-events:none;padding-block-start:var(--safe-area-top)}.toast{display:flex;align-items:center;gap:var(--space-md);margin:var(--space-md);padding:var(--space-lg);border-radius:var(--radius-md);box-shadow:var(--shadow-lg);pointer-events:auto;opacity:0;transform:translateY(-100%);transition:all var(--transition-base);backdrop-filter:blur(8px)}.toast-show{opacity:1;transform:translateY(0)}.toast-info{background-color:#e8f5e9;color:#1b5e20;border-inline-start:4px solid var(--color-success)}.toast-error{background-color:#ffebee;color:#b71c1c;border-inline-start:4px solid var(--color-error)}.toast-icon{font-size:var(--font-size-2xl);line-height:1;flex-shrink:0}.toast-info .toast-icon{color:var(--color-success)}.toast-error .toast-icon{color:var(--color-error)}.toast-message{flex:1;font-size:var(--font-size-base);line-height:var(--line-height-normal);word-wrap:break-word}.toast-dismiss{background:none;border:none;color:inherit;font-size:var(--font-size-2xl);line-height:1;cursor:pointer;padding:var(--space-sm);min-inline-size:var(--touch-target-min);min-block-size:var(--touch-target-min);display:flex;align-items:center;justify-content:center;border-radius:var(--radius-sm);opacity:.7;transition:all var(--transition-fast);flex-shrink:0}.toast-dismiss:hover,.toast-dismiss:focus{opacity:1;background-color:#0000000d}.logo-container{display:flex;flex-direction:column;align-items:center}.logo{min-block-size:200px;aspect-ratio:335 / 366;max-inline-size:100%;block-size:auto;object-fit:contain}.manage-items{padding:var(--space-md);display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:var(--space-md)}.manage-items a{display:flex;align-items:center;justify-content:center;flex-direction:column;gap:var(--space-sm);text-align:center;padding:var(--space-lg);background-color:var(--color-primary, #ffffff);color:var(--color-surface, #1f2937);border:1px solid var(--color-border, #dce3f0);border-radius:var(--radius-md);font-weight:var(--font-weight-medium);font-size:var(--font-size-base);min-block-size:96px;transition:all var(--transition-base);box-shadow:var(--shadow-sm)}.manage-items a i{font-size:1.25rem;color:inherit}.manage-items a span{display:inline-block;line-height:1.4}.manage-items a:hover,.manage-items a:focus-visible{background-color:var(--color-primary-10, #eef2fb);border-color:var(--color-primary);color:var(--color-primary-dark, #2d3f8d);transform:translateY(-2px);box-shadow:var(--shadow-md);text-decoration:none}.manage-items a:focus-visible{outline:3px solid var(--color-primary);outline-offset:3px}#offline-indicator{display:none;background-color:#4c65aef2;color:#fff;text-align:center;padding:var(--space-md);padding-block-start:calc(var(--space-md) + var(--safe-area-top));position:fixed;inset-block-start:0;inset-inline:0;z-index:var(--z-overlay);font-size:var(--font-size-sm);box-shadow:var(--shadow-md);backdrop-filter:blur(8px)}#loading-indicator{position:fixed;inset-block-start:50%;inset-inline-start:50%;transform:translate(-50%,-50%);background-color:#000000d9;color:#fff;padding:var(--space-2xl) var(--space-3xl);border-radius:var(--radius-lg);z-index:var(--z-overlay);font-size:var(--font-size-lg);backdrop-filter:blur(8px);box-shadow:var(--shadow-xl)}#cache-progress-container{position:fixed;inset-block-end:0;inset-inline:0;background-color:#000000d9;color:#fff;padding:var(--space-sm);padding-block-end:calc(var(--space-sm) + var(--safe-area-bottom));font-size:var(--font-size-sm);text-align:center;z-index:var(--z-overlay);backdrop-filter:blur(4px)}#cache-progress-bar{block-size:3px;background-color:var(--color-success-light);inline-size:0%;transition:inline-size var(--transition-base)}.skeleton{background:linear-gradient(90deg,var(--color-border, #e5e7eb) 0%,var(--color-surface, #f3f4f6) 50%,var(--color-border, #e5e7eb) 100%);background-size:200% 100%;animation:skeleton-loading 1.5s ease-in-out infinite;border-radius:var(--radius-md);position:relative;overflow:hidden}@keyframes skeleton-loading{0%{background-position:200% 0}to{background-position:-200% 0}}.skeleton--header{height:60px;margin-block-end:var(--space-lg)}.skeleton--card{height:200px;margin-block-end:var(--space-md)}.skeleton--card-small{height:120px;margin-block-end:var(--space-md)}.skeleton--text{height:16px;margin-block-end:var(--space-sm);border-radius:var(--radius-sm)}.skeleton--text-wide{height:16px;width:100%;margin-block-end:var(--space-sm);border-radius:var(--radius-sm)}.skeleton--text-short{height:16px;width:60%;margin-block-end:var(--space-sm);border-radius:var(--radius-sm)}.skeleton--button{height:40px;width:120px;border-radius:var(--radius-md)}.skeleton--avatar{width:48px;height:48px;border-radius:50%}.skeleton-grid{display:grid;gap:var(--space-md)}.skeleton-grid--2col{grid-template-columns:repeat(auto-fit,minmax(300px,1fr))}.skeleton-grid--3col{grid-template-columns:repeat(auto-fit,minmax(250px,1fr))}.loading-state{padding:var(--space-lg);min-height:400px}.skeleton--pulse{animation:skeleton-pulse 2s cubic-bezier(.4,0,.6,1) infinite}@keyframes skeleton-pulse{0%,to{opacity:1}50%{opacity:.5}}.button--loading{position:relative;color:transparent!important;pointer-events:none}.button--loading:after{content:"";position:absolute;width:16px;height:16px;top:50%;left:50%;margin-left:-8px;margin-top:-8px;border:2px solid transparent;border-top-color:currentColor;border-radius:50%;animation:button-loading-spinner .6s linear infinite;color:var(--color-surface, white)}@keyframes button-loading-spinner{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.spinner{display:inline-block;width:16px;height:16px;border:2px solid transparent;border-top-color:currentColor;border-radius:50%;animation:button-loading-spinner .6s linear infinite;vertical-align:middle;margin-inline-end:var(--space-xs)}.spinner--large{width:32px;height:32px;border-width:3px}.controls-container{margin-block-end:var(--space-lg);display:flex;flex-direction:column;gap:var(--space-sm)}.sort-options{display:flex;gap:var(--space-sm);align-items:center;justify-content:center}.sort-btn,.filter-toggle-btn{display:inline-flex;align-items:center;justify-content:center;min-inline-size:48px;min-block-size:48px;padding:var(--space-sm);background-color:#fff;border:2px solid var(--color-primary);border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-base);font-size:var(--font-size-xl);font-weight:var(--font-weight-medium)}.sort-btn:hover,.filter-toggle-btn:hover{background-color:var(--color-primary);color:#fff;transform:translateY(-2px) scale(1.05);box-shadow:var(--shadow-md)}.sort-btn:active,.filter-toggle-btn:active{transform:translateY(0) scale(.98)}.filter-toggle-btn{background-color:var(--color-secondary);border-color:var(--color-text-muted)}.filter-toggle-btn:hover{background-color:var(--color-text-muted);color:#fff}.filter-options{display:flex;flex-wrap:wrap;gap:var(--space-sm);align-items:center;justify-content:center;padding:var(--space-md);background-color:var(--color-surface);border-radius:var(--radius-md);box-shadow:var(--shadow-sm);overflow:hidden;max-block-size:200px;opacity:1;transition:all var(--transition-base)}.filter-options.hidden{max-block-size:0;padding:0;opacity:0;margin:0}.filter-options label{margin:0;font-weight:var(--font-weight-medium);color:var(--color-text)}.filter-options select{flex:1;min-inline-size:150px;padding:var(--space-sm);border:1px solid var(--color-border);border-radius:var(--radius-sm);font-size:var(--font-size-base)}.sort-control{display:inline-flex;align-items:center;gap:var(--space-sm);padding:var(--space-sm) var(--space-lg);background-color:#fff;border:2px solid var(--color-primary);border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-base);font-size:var(--font-size-base);font-weight:var(--font-weight-medium)}.sort-control:hover{background-color:var(--color-primary);color:#fff;transform:translateY(-1px)}.sort-arrow:before{content:"↕";font-size:1.2em}.sort-control.ascending .sort-arrow:before{content:"↑"}.sort-control.descending .sort-arrow:before{content:"↓"}.badge-tracker{--badge-proie: #6366f1;--badge-proie-bg: #eef2ff;--badge-battue: #059669;--badge-battue-bg: #ecfdf5;--badge-pending: #e65100;--badge-pending-bg: #fff3e0;--badge-delivered: #1565c0;--badge-delivered-bg: #e3f2fd;--badge-approved: #2e7d32;--badge-star-filled: #f59e0b;--badge-star-empty: #d1d5db;background:linear-gradient(135deg,#e8f5ec,#e8eaf6);min-height:100vh;color:var(--color-text);padding-bottom:var(--space-3xl)}.badge-tracker__skip-link{position:absolute;top:-40px;left:0;background:var(--color-primary);color:var(--color-selected-text);padding:var(--space-sm) var(--space-md);z-index:var(--z-sticky);text-decoration:none;border-radius:0 0 var(--radius-md) 0;font-weight:var(--font-weight-semibold)}.badge-tracker__skip-link:focus{top:0}.badge-tracker__header{background:var(--gradient-primary);color:var(--color-selected-text);padding:var(--space-lg);position:sticky;top:0;z-index:var(--z-sticky);box-shadow:var(--shadow-md)}.badge-tracker__header-top{display:flex;align-items:center;justify-content:space-between;gap:var(--space-md)}.badge-tracker__title{font-size:var(--font-size-xl);font-weight:var(--font-weight-bold);display:flex;align-items:center;gap:var(--space-sm)}.badge-tracker__subtitle{font-size:var(--font-size-sm);opacity:.9;margin-top:var(--space-xs)}.badge-tracker__actions{display:flex;gap:var(--space-sm)}.badge-tracker__action-btn{position:relative;display:inline-flex;align-items:center;justify-content:center;width:var(--touch-target-min);height:var(--touch-target-min);border-radius:var(--radius-full);border:2px solid rgb(255 255 255 / .3);background:#ffffff1f;color:var(--color-selected-text);cursor:pointer;transition:var(--transition-fast)}.badge-tracker__action-btn:hover{background:#fff3;border-color:#ffffff80}.badge-tracker__action-btn:focus{outline:none;box-shadow:0 0 0 3px #ffffff59}.badge-tracker__action-btn--active{background:var(--color-selected-text);color:var(--color-primary);border-color:var(--color-selected-text)}.badge-tracker__action-icon{font-size:1.1rem}.badge-tracker__action-badge{position:absolute;top:-4px;right:-4px;min-width:20px;height:20px;padding:0 6px;border-radius:var(--radius-full);background:#ef4444;color:var(--color-selected-text);font-size:.7rem;font-weight:var(--font-weight-bold);display:flex;align-items:center;justify-content:center;box-shadow:var(--shadow-sm)}.badge-tracker__action-badge--warning{background:var(--badge-pending)}.badge-tracker__action-badge--info{background:var(--badge-delivered)}.badge-tracker__tabs{display:flex;background:var(--color-surface);border-bottom:1px solid var(--color-border);overflow-x:auto}.badge-tracker__tab{flex:1;min-width:120px;padding:var(--space-md);border:none;background:transparent;font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);color:var(--color-text-muted);cursor:pointer;transition:var(--transition-fast);border-bottom:3px solid transparent;display:inline-flex;align-items:center;justify-content:center;gap:var(--space-xs)}.badge-tracker__tab:hover{color:var(--color-text);background:var(--color-secondary)}.badge-tracker__tab--active{color:var(--color-primary);border-bottom-color:var(--color-primary)}.badge-tracker__tab:focus{outline:none;box-shadow:inset 0 0 0 2px var(--color-primary)}.badge-tracker__tab-count{display:inline-flex;align-items:center;justify-content:center;min-width:20px;height:20px;padding:0 6px;border-radius:var(--radius-full);background:var(--color-secondary);font-size:.7rem}.badge-tracker__tab-count--alert{background:var(--badge-pending);color:var(--color-selected-text)}.badge-tracker__tab--active .badge-tracker__tab-count:not(.badge-tracker__tab-count--alert){background:var(--color-primary);color:var(--color-selected-text)}.badge-tracker__filter-bar{background:var(--color-surface);padding:var(--space-md);border-bottom:1px solid var(--color-border);display:flex;flex-direction:column;gap:var(--space-sm)}@media(min-width:640px){.badge-tracker__filter-bar{flex-direction:row;align-items:center;justify-content:space-between}}.badge-tracker__search{position:relative;flex:1;max-width:420px}.badge-tracker__search-input{width:100%;padding:var(--space-sm) var(--space-md);padding-left:2.5rem;border:2px solid var(--color-border);border-radius:var(--radius-full);font-size:var(--font-size-base);transition:var(--transition-fast);background:var(--color-surface)}.badge-tracker__search-input:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px #0f7a5a33}.badge-tracker__search-icon{position:absolute;left:var(--space-md);top:50%;transform:translateY(-50%);color:var(--color-text-muted)}.badge-tracker__content{padding:var(--space-md);max-width:900px;margin:0 auto}.badge-tracker__stats{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:var(--space-sm);margin-bottom:var(--space-lg)}@media(min-width:640px){.badge-tracker__stats{grid-template-columns:repeat(4,minmax(0,1fr))}}.badge-tracker__stat-card{background:var(--color-surface);border-radius:var(--radius-md);padding:var(--space-md);text-align:center;box-shadow:var(--shadow-sm);border:1px solid var(--color-border);cursor:pointer;transition:var(--transition-fast)}.badge-tracker__stat-card:hover{box-shadow:var(--shadow-md);transform:translateY(-1px)}.badge-tracker__stat-card--highlight{border-color:var(--badge-pending);background:var(--badge-pending-bg)}.badge-tracker__stat-value{font-size:var(--font-size-2xl);font-weight:var(--font-weight-bold);color:var(--color-primary)}.badge-tracker__stat-card--highlight .badge-tracker__stat-value{color:var(--badge-pending)}.badge-tracker__stat-label{font-size:var(--font-size-xs);color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.04em}.badge-tracker__list-header{font-size:var(--font-size-lg);font-weight:var(--font-weight-bold);margin-bottom:var(--space-md);display:flex;align-items:center;justify-content:space-between}.badge-tracker__list-count{font-size:var(--font-size-sm);font-weight:var(--font-weight-normal);color:var(--color-text-muted)}.badge-tracker__participant-list{list-style:none}.badge-tracker__participant-card{background:var(--color-surface);border-radius:var(--radius-lg);margin-bottom:var(--space-sm);overflow:hidden;box-shadow:var(--shadow-sm);border:1px solid var(--color-border);transition:var(--transition-fast)}.badge-tracker__participant-card:nth-child(odd){background:#e8f5ec}.badge-tracker__participant-card:nth-child(2n){background:#e8eaf6}.badge-tracker__participant-card:hover{box-shadow:var(--shadow-md);transform:translateY(-1px)}.badge-tracker__participant-header{display:flex;align-items:center;padding:var(--space-md);gap:var(--space-md);cursor:pointer;border:none;background:transparent;width:100%;text-align:left}.badge-tracker__participant-header:focus{outline:none}.badge-tracker__avatar{width:var(--touch-target-min);height:var(--touch-target-min);border-radius:var(--radius-full);background:linear-gradient(135deg,var(--color-primary-light) 0%,var(--color-primary) 100%);display:flex;align-items:center;justify-content:center;color:var(--color-selected-text);font-weight:var(--font-weight-bold);font-size:var(--font-size-base);flex-shrink:0}.badge-tracker__participant-info{flex:1;min-width:0}.badge-tracker__participant-name{font-weight:var(--font-weight-semibold);font-size:var(--font-size-base);color:var(--color-text);margin-bottom:2px;display:flex;align-items:center;gap:var(--space-xs)}.badge-tracker__indicators{display:inline-flex;gap:4px}.badge-tracker__indicator{width:8px;height:8px;border-radius:var(--radius-full)}.badge-tracker__indicator--pending{background:var(--badge-pending)}.badge-tracker__indicator--delivery{background:var(--badge-delivered)}.badge-tracker__totem{font-size:var(--font-size-sm);color:var(--color-text-light);font-style:italic}.badge-tracker__badge-preview{display:flex;align-items:center;gap:var(--space-xs);flex-shrink:0}.badge-tracker__preview-item{position:relative;width:36px;height:36px}.badge-tracker__preview-image{width:100%;height:100%;object-fit:contain;border-radius:var(--radius-sm)}.badge-tracker__preview-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;background:var(--color-surface);border-radius:var(--radius-sm);font-size:1.2rem}.badge-tracker__preview-stars{position:absolute;bottom:-4px;left:50%;transform:translate(-50%);display:flex;gap:1px;background:var(--color-surface);padding:1px 4px;border-radius:var(--radius-full);box-shadow:var(--shadow-sm)}.badge-tracker__preview-star{font-size:.5rem;color:var(--badge-star-filled)}.badge-tracker__preview-star--empty{color:var(--badge-star-empty)}.badge-tracker__preview-star--pending{color:var(--badge-pending)}.badge-tracker__preview-delivery-indicator{position:absolute;top:-2px;right:-2px;width:10px;height:10px;border-radius:var(--radius-full);background:var(--badge-delivered);border:2px solid var(--color-surface)}.badge-tracker__preview-more{width:36px;height:36px;border-radius:var(--radius-full);background:var(--color-secondary);border:2px solid var(--color-border);display:flex;align-items:center;justify-content:center;font-size:var(--font-size-xs);font-weight:var(--font-weight-semibold);color:var(--color-text-muted)}.badge-tracker__chevron{color:var(--color-text-muted);transition:transform var(--transition-fast);flex-shrink:0}.badge-tracker__chevron--expanded{transform:rotate(180deg)}.badge-tracker__badge-details{padding:0 var(--space-md) var(--space-md);animation:badge-slide-down .2s ease-out}@keyframes badge-slide-down{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.badge-tracker__badge-card{background:#ffffffd9;border-radius:var(--radius-md);padding:var(--space-md);margin-bottom:var(--space-sm);border:1px solid var(--color-border)}.badge-tracker__badge-card:last-child{margin-bottom:0}.badge-tracker__badge-header{display:flex;align-items:flex-start;gap:var(--space-md);margin-bottom:var(--space-md)}.badge-tracker__badge-image-container{position:relative;flex-shrink:0}.badge-tracker__badge-image,.badge-tracker__badge-placeholder{width:56px;height:56px;object-fit:contain;border-radius:var(--radius-sm)}.badge-tracker__badge-placeholder{display:flex;align-items:center;justify-content:center;background:var(--color-secondary);font-size:1.5rem}.badge-tracker__badge-info{flex:1;min-width:0}.badge-tracker__badge-title{font-weight:var(--font-weight-semibold);font-size:var(--font-size-base);color:var(--color-text);margin-bottom:var(--space-xs)}.badge-tracker__badge-progress-text{font-size:var(--font-size-sm);color:var(--color-text-light)}.badge-tracker__star-progress{display:flex;gap:var(--space-sm);flex-wrap:wrap}.badge-tracker__star-slot{display:flex;flex-direction:column;align-items:center;gap:var(--space-xs);padding:var(--space-sm);background:var(--color-secondary);border-radius:var(--radius-md);border:2px solid var(--color-border);flex:1;min-width:90px;position:relative}.badge-tracker__star-slot--delivered{border-color:var(--badge-delivered);background:var(--badge-delivered-bg)}.badge-tracker__star-slot--approved{border-color:var(--badge-star-filled);background:#fffbeb}.badge-tracker__star-slot--pending{border-color:var(--badge-pending);border-style:dashed;background:var(--badge-pending-bg)}.badge-tracker__star-icon{font-size:1.4rem;color:var(--badge-star-empty)}.badge-tracker__star-slot--approved .badge-tracker__star-icon,.badge-tracker__star-slot--delivered .badge-tracker__star-icon{color:var(--badge-star-filled)}.badge-tracker__star-slot--pending .badge-tracker__star-icon{color:var(--badge-pending)}.badge-tracker__star-delivery-badge{position:absolute;top:-6px;right:-6px;width:20px;height:20px;border-radius:var(--radius-full);background:var(--badge-delivered);color:var(--color-selected-text);display:flex;align-items:center;justify-content:center;font-size:.6rem}.badge-tracker__star-type{display:inline-flex;align-items:center;gap:2px;padding:2px 6px;border-radius:var(--radius-full);font-size:.65rem;font-weight:var(--font-weight-semibold);text-transform:uppercase}.badge-tracker__star-type--proie{background:var(--badge-proie-bg);color:var(--badge-proie)}.badge-tracker__star-type--battue{background:var(--badge-battue-bg);color:var(--badge-battue)}.badge-tracker__star-status{font-size:.65rem;font-weight:var(--font-weight-semibold);text-transform:uppercase}.badge-tracker__star-status--pending{color:var(--badge-pending)}.badge-tracker__star-status--needs-delivery{color:var(--badge-delivered)}.badge-tracker__star-date{font-size:.7rem;color:var(--color-text-muted)}.badge-tracker__add-star-btn{display:flex;align-items:center;justify-content:center;gap:var(--space-xs);padding:var(--space-sm);background:transparent;border:2px dashed var(--color-border);border-radius:var(--radius-md);color:var(--color-text-muted);font-size:var(--font-size-sm);cursor:pointer;transition:var(--transition-fast);flex:1;min-width:90px}.badge-tracker__add-star-btn:hover{border-color:var(--color-primary);color:var(--color-primary);background:#e8f5ec}.badge-tracker__add-star-btn:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px #0f7a5a33}.badge-tracker__queue-section{margin-bottom:var(--space-lg)}.badge-tracker__queue-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--space-md);gap:var(--space-sm);flex-wrap:wrap}.badge-tracker__queue-title{font-size:var(--font-size-lg);font-weight:var(--font-weight-bold);display:flex;align-items:center;gap:var(--space-sm)}.badge-tracker__queue-icon{width:24px;height:24px;border-radius:var(--radius-full);display:flex;align-items:center;justify-content:center;font-size:.85rem}.badge-tracker__queue-icon--pending{background:var(--badge-pending-bg);color:var(--badge-pending)}.badge-tracker__queue-icon--delivery{background:var(--badge-delivered-bg);color:var(--badge-delivered)}.badge-tracker__queue-item{background:var(--color-surface);border-radius:var(--radius-md);padding:var(--space-md);margin-bottom:var(--space-sm);border:1px solid var(--color-border);display:flex;align-items:center;gap:var(--space-md);transition:var(--transition-fast)}.badge-tracker__queue-item:hover{box-shadow:var(--shadow-sm)}.badge-tracker__queue-item--pending{border-left:4px solid var(--badge-pending)}.badge-tracker__queue-item--delivery{border-left:4px solid var(--badge-delivered)}.badge-tracker__queue-badge-image,.badge-tracker__queue-badge-placeholder{width:48px;height:48px;object-fit:contain;border-radius:var(--radius-sm)}.badge-tracker__queue-badge-placeholder{display:flex;align-items:center;justify-content:center;background:var(--color-secondary);font-size:1.4rem}.badge-tracker__queue-content{flex:1;min-width:0}.badge-tracker__queue-item-header{display:flex;align-items:center;gap:var(--space-sm);margin-bottom:var(--space-xs);flex-wrap:wrap}.badge-tracker__queue-name{font-weight:var(--font-weight-semibold);font-size:var(--font-size-base)}.badge-tracker__queue-star{display:inline-flex;align-items:center;gap:2px;padding:2px 8px;border-radius:var(--radius-full);font-size:.7rem;font-weight:var(--font-weight-semibold);background:var(--badge-star-filled);color:var(--color-selected-text)}.badge-tracker__queue-type{display:inline-flex;align-items:center;gap:2px;padding:2px 6px;border-radius:var(--radius-full);font-size:.6rem;font-weight:var(--font-weight-semibold);text-transform:uppercase}.badge-tracker__queue-type--proie{background:var(--badge-proie-bg);color:var(--badge-proie)}.badge-tracker__queue-type--battue{background:var(--badge-battue-bg);color:var(--badge-battue)}.badge-tracker__queue-badge-name{font-size:var(--font-size-sm);color:var(--color-text-light)}.badge-tracker__queue-details{font-size:var(--font-size-sm);color:var(--color-text)}.badge-tracker__queue-date{font-size:var(--font-size-xs);color:var(--color-text-muted);margin-top:var(--space-xs)}.badge-tracker__queue-actions{display:flex;gap:var(--space-xs);flex-shrink:0}.badge-tracker__icon-btn{width:36px;height:36px;border-radius:var(--radius-full);border:2px solid var(--color-border);background:var(--color-surface);color:var(--color-text-light);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:var(--transition-fast)}.badge-tracker__icon-btn:hover{background:var(--color-secondary)}.badge-tracker__icon-btn:focus{outline:none;box-shadow:0 0 0 3px #0f7a5a33}.badge-tracker__icon-btn--approve{border-color:var(--badge-approved);color:var(--badge-approved)}.badge-tracker__icon-btn--approve:hover{background:var(--badge-approved);color:var(--color-selected-text)}.badge-tracker__icon-btn--deliver{border-color:var(--badge-delivered);color:var(--badge-delivered)}.badge-tracker__icon-btn--deliver:hover{background:var(--badge-delivered);color:var(--color-selected-text)}.badge-tracker__icon-btn--reject{border-color:#ef4444;color:#ef4444}.badge-tracker__icon-btn--reject:hover{background:#ef4444;color:var(--color-selected-text)}.badge-tracker__empty-state{text-align:center;padding:var(--space-xl);background:var(--color-surface);border-radius:var(--radius-lg);border:2px dashed var(--color-border)}.badge-tracker__empty-icon{font-size:3rem;margin-bottom:var(--space-md)}.badge-tracker__empty-title{font-size:var(--font-size-lg);font-weight:var(--font-weight-semibold);margin-bottom:var(--space-xs)}.badge-tracker__empty-description{font-size:var(--font-size-sm);color:var(--color-text-muted)}.badge-tracker__fab{position:fixed;bottom:var(--space-lg);right:var(--space-lg);width:56px;height:56px;border-radius:var(--radius-full);background:var(--gradient-primary);color:var(--color-selected-text);border:none;box-shadow:var(--shadow-lg);cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:1.5rem;transition:var(--transition-fast);z-index:var(--z-fixed)}.badge-tracker__fab:hover{transform:scale(1.05)}.badge-tracker__fab:focus{outline:none;box-shadow:0 0 0 4px #0f7a5a59,var(--shadow-lg)}.badge-tracker__modal-container{position:fixed;inset:0;z-index:var(--z-modal)}.badge-tracker__modal-overlay{position:fixed;inset:0;background:#1d2f2a99}.badge-tracker__modal{position:fixed;inset:auto 0 0;background:var(--color-surface);width:100%;max-width:560px;max-height:90vh;margin:0 auto;overflow-y:auto;border-radius:var(--radius-lg) var(--radius-lg) 0 0;animation:badge-modal-slide .3s ease-out}@media(min-width:640px){.badge-tracker__modal{inset:50% auto auto 50%;transform:translate(-50%,-50%);border-radius:var(--radius-lg)}}@keyframes badge-modal-slide{0%{opacity:0;transform:translateY(100px)}to{opacity:1;transform:translateY(0)}}.badge-tracker__modal-header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-lg);border-bottom:1px solid var(--color-border);position:sticky;top:0;background:var(--color-surface)}.badge-tracker__modal-title{font-size:var(--font-size-lg);font-weight:var(--font-weight-bold)}.badge-tracker__modal-close{width:36px;height:36px;border-radius:var(--radius-full);border:none;background:var(--color-secondary);color:var(--color-text-light);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:var(--transition-fast)}.badge-tracker__modal-close:hover{background:var(--color-border)}.badge-tracker__modal-close:focus{outline:none;box-shadow:0 0 0 3px #0f7a5a4d}.badge-tracker__modal-body{padding:var(--space-lg)}.badge-tracker__modal-footer{display:flex;gap:var(--space-sm);padding:var(--space-lg);padding-top:0}.badge-tracker__badge-selector{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:var(--space-sm)}.badge-tracker__badge-option{display:flex;flex-direction:column;align-items:center;gap:var(--space-xs);padding:var(--space-sm);border:2px solid var(--color-border);border-radius:var(--radius-md);cursor:pointer;transition:var(--transition-fast);background:var(--color-surface)}.badge-tracker__badge-option:hover{background:var(--color-secondary)}.badge-tracker__badge-option--selected{border-color:var(--color-primary);background:#e8f5ec}.badge-tracker__badge-option input{position:absolute;opacity:0}.badge-tracker__badge-option-image{width:48px;height:48px;object-fit:contain}.badge-tracker__badge-option-placeholder{width:48px;height:48px;display:flex;align-items:center;justify-content:center;background:var(--color-secondary);border-radius:var(--radius-sm)}.badge-tracker__badge-option-name{font-size:var(--font-size-xs);font-weight:var(--font-weight-medium);text-align:center;line-height:var(--line-height-tight)}.badge-tracker__star-info{display:flex;align-items:center;justify-content:space-between;gap:var(--space-sm);padding:var(--space-sm);border-radius:var(--radius-md);background:var(--color-secondary);border:1px solid var(--color-border);margin-bottom:var(--space-md);font-size:var(--font-size-sm)}.badge-tracker__star-info-label{font-weight:var(--font-weight-semibold)}.badge-tracker__star-info-value{font-weight:var(--font-weight-semibold);color:var(--color-primary)}.badge-tracker__type-selector{display:flex;gap:var(--space-sm)}.badge-tracker__type-option{flex:1;display:flex;flex-direction:column;align-items:center;gap:var(--space-xs);padding:var(--space-md);border:2px solid var(--color-border);border-radius:var(--radius-md);cursor:pointer;transition:var(--transition-fast);background:var(--color-surface)}.badge-tracker__type-option:hover{background:var(--color-secondary)}.badge-tracker__type-option--selected{border-color:var(--color-primary);background:#e8f5ec}.badge-tracker__type-option input{position:absolute;opacity:0}.badge-tracker__type-icon{font-size:1.4rem}.badge-tracker__type-label{font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold)}.badge-tracker__type-desc{font-size:var(--font-size-xs);color:var(--color-text-muted)}.visible{display:block!important}.highlight{background-color:#ff0;transition:background-color .5s ease}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border-width:0}.error,.message{padding:var(--space-lg);margin-block-end:var(--space-lg);border-radius:var(--radius-md);border-inline-start:4px solid}.error{background-color:#ffebee;color:var(--color-error);border-color:var(--color-error)}.message{background-color:#e8f5e9;color:var(--color-success);border-color:var(--color-success)}.skeleton{opacity:.7;animation:pulse 1.5s ease-in-out infinite}@keyframes pulse{0%,to{opacity:.7}50%{opacity:.4}}.skeleton-text,.skeleton-button{background-color:var(--color-border-light);color:transparent;border:none;border-radius:var(--radius-sm)}.skeleton-guest-list .guest-row,.skeleton .participant-row{background-color:var(--color-border-light);block-size:1.5em;margin:var(--space-sm) 0;border-radius:var(--radius-sm)}.point-change{position:absolute;inset-inline-end:var(--space-md);animation:fadeUp 2s forwards;font-weight:var(--font-weight-bold)}@keyframes fadeUp{0%{opacity:1;transform:translateY(0)}to{opacity:0;transform:translateY(-20px)}}@media(width<=480px){:root{--space-md: .75rem;--space-lg: 1rem}.language-toggle,.home-icon{min-inline-size:40px;min-block-size:40px}.lang-btn{padding:var(--space-sm) var(--space-md);font-size:var(--font-size-xs)}.logo{max-inline-size:70%}h1{font-size:var(--font-size-2xl);margin-block:var(--space-md)}h2{font-size:var(--font-size-xl);margin-block:var(--space-sm)}.status-buttons{grid-template-columns:repeat(2,1fr);padding:var(--space-md)}.status-button{padding:var(--space-md);font-size:var(--font-size-sm)}}@media(width>=601px)and (width<768px){.manage-items{grid-template-columns:repeat(2,1fr)}.status-buttons{grid-template-columns:repeat(4,1fr)}.parent-dashboard__actions-grid,.participant-card__forms{grid-template-columns:repeat(2,1fr)}}@media(width>=768px){body{padding:var(--space-2xl)}.logo{max-inline-size:400px}.dashboard-menu{grid-template-columns:repeat(2,1fr)}.manage-items{grid-template-columns:repeat(3,1fr)}.point-btn,.status-button{min-inline-size:120px}.fixed-bottom,.status-buttons{padding:var(--space-xl);grid-template-columns:repeat(auto-fit,minmax(140px,1fr))}.parent-dashboard{max-inline-size:var(--container-md);padding:var(--space-xl)}.parent-dashboard__actions-grid,.participant-card__forms{grid-template-columns:repeat(2,1fr)}.parent-dashboard__footer{flex-direction:row;align-items:center;justify-content:space-between}.parent-dashboard__footer-actions{flex-direction:row;flex:1}.participant-documents{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:var(--space-lg)}.badge-grid{grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:var(--space-xl)}.list-item,.name-item,.participant-row{transition:all var(--transition-base)}.list-item:hover,.name-item:hover,.participant-row:hover{transform:translate(4px);box-shadow:var(--shadow-sm)}}@media(width>=1024px){:root{--font-size-base: 1.125rem}.dashboard-menu{grid-template-columns:repeat(3,1fr)}.manage-items{grid-template-columns:repeat(4,1fr)}.attendance-container{max-inline-size:var(--container-sm);margin-inline:auto}.parent-dashboard{max-inline-size:var(--container-lg);margin-inline:auto}.participant-card__forms{grid-template-columns:repeat(3,1fr)}.participant-card__statement{flex-direction:row;justify-content:space-between;align-items:center}.fixed-bottom,.status-buttons{margin-inline:auto;inset-inline:auto;inline-size:100%}}@media print{@page{size:letter;margin:1cm}body{background:#fff;color:#000}body:before,body:after{display:none}.language-toggle,.home-icon,.fixed-bottom,.status-buttons,button,.btn,.dashboard-button,.toast,#offline-indicator,#loading-indicator{display:none!important}.surface,form,table,.group{box-shadow:none;border:1px solid #ddd}a{text-decoration:underline}a[href^=http]:after{content:" (" attr(href) ")";font-size:.8em;color:#666}}@media(prefers-contrast:high){:root{--color-border: #000;--shadow-base: 0 0 0 1px #000}}.parent-dashboard{max-inline-size:100%;margin-inline:auto;padding:var(--space-md);display:flex;flex-direction:column;gap:var(--space-lg)}.parent-dashboard__header{text-align:center;padding:var(--space-lg) var(--space-md);background:#fff;border-radius:var(--radius-lg);box-shadow:var(--shadow-md)}.parent-dashboard__title{font-size:var(--font-size-xl);font-weight:var(--font-weight-bold);margin:0 0 var(--space-xs) 0;color:var(--color-text)}.parent-dashboard__subtitle{font-size:var(--font-size-base);margin:0;font-weight:var(--font-weight-medium);color:var(--color-text-secondary)}.back-link{display:inline-block;margin-block-start:var(--space-md);color:var(--color-primary);text-decoration:underline;font-size:var(--font-size-sm)}.back-link:hover{color:var(--color-primary-dark)}.parent-dashboard__actions{padding:0}.parent-dashboard__actions-grid{display:grid;gap:var(--space-md);grid-template-columns:1fr}.parent-dashboard__participants{display:flex;flex-direction:column;gap:var(--space-md)}.parent-dashboard__empty{text-align:center;padding:var(--space-xl);color:var(--color-text-secondary);font-style:italic}.parent-dashboard__footer{display:flex;flex-direction:column;gap:var(--space-md);margin-block-start:var(--space-lg)}.parent-dashboard__footer-actions{display:flex;flex-direction:column;gap:var(--space-sm)}.visually-hidden{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border-width:0}.parent-item{background-color:var(--color-surface);border-radius:var(--radius-md);padding:var(--space-lg);margin-block-end:var(--space-md);box-shadow:var(--shadow-base)}.parent-item h2{color:var(--color-primary);margin-block-start:0}#news-widget{inline-size:100%}.news-accordion{border:1px solid var(--color-border);border-radius:var(--radius-sm);margin-block-end:var(--space-md);overflow:hidden}.news-accordion-header{background-color:var(--color-secondary);padding:var(--space-md);cursor:pointer;user-select:none;font-weight:var(--font-weight-medium);transition:background-color var(--transition-fast)}.news-accordion-header:hover{background-color:var(--color-border-light)}.news-accordion-content{padding:var(--space-md);display:none;background-color:var(--color-surface)}.news-accordion.open .news-accordion-content{display:block}.calendars-table{inline-size:100%;border-collapse:collapse;background-color:var(--color-surface);box-shadow:0 2px 4px #00000014;display:block}.calendars-table thead,.calendars-table th{display:none}.calendars-table tr{display:block;border:1px solid var(--color-border);margin-block-end:var(--space-md);border-radius:var(--radius-sm);overflow:hidden;background:var(--color-surface)}.calendars-table td{display:block;position:relative;padding:var(--space-sm) var(--space-md) var(--space-sm) 45%;border-bottom:1px solid var(--color-border-light);text-align:end}.calendars-table td:last-child{border-bottom:none}.calendars-table td:before{content:attr(data-label);position:absolute;inset-block-start:50%;inset-inline-start:var(--space-md);transform:translateY(-50%);inline-size:40%;padding-inline-end:var(--space-sm);white-space:nowrap;font-weight:var(--font-weight-semibold);text-align:start;color:var(--color-text-muted)}.calendars-table input[type=number]{inline-size:100%;max-inline-size:none;padding:var(--space-sm);box-sizing:border-box}@media(min-width:720px){.calendars-table{display:table}.calendars-table thead{display:table-header-group}.calendars-table tbody{display:table-row-group}.calendars-table tr{display:table-row;border:none;margin:0}.calendars-table td,.calendars-table th{display:table-cell;padding:var(--space-md);text-align:start;border:1px solid var(--color-border)}.calendars-table th{background-color:var(--color-secondary);font-weight:var(--font-weight-semibold);position:sticky;top:0;z-index:var(--z-sticky)}.calendars-table td:before{content:none}.calendars-table input[type=number]{inline-size:100%;max-inline-size:110px}}.pending-update{font-size:var(--font-size-sm);font-style:italic;margin-inline-start:var(--space-sm);color:var(--color-warning)}body.offline .pending-update{display:inline-block}body.online .pending-update{display:none}.fiche-sante-form{max-inline-size:var(--container-sm);margin-inline:auto;padding:var(--space-lg)}.form-status{margin-block-end:var(--space-md);padding:var(--space-sm);border-radius:var(--radius-sm)}.form-status .filled{color:var(--color-success);font-weight:var(--font-weight-semibold)}.form-status .missing{color:var(--color-error);font-weight:var(--font-weight-semibold)}.view-form{background-color:var(--color-success-light);border:none;color:#fff;padding:var(--space-xs) var(--space-sm);text-decoration:none;display:inline-block;font-size:var(--font-size-sm);margin:var(--space-xs);cursor:pointer;border-radius:var(--radius-sm);transition:all var(--transition-fast)}.view-form:hover{background-color:var(--color-success);transform:translateY(-1px)}#form-content{max-block-size:70vh;overflow-y:auto;padding:var(--space-md)}#form-content label{display:block;margin-block-start:var(--space-md)}#form-content input[type=text],#form-content input[type=email],#form-content input[type=tel],#form-content textarea,#form-content select{inline-size:100%;padding:var(--space-sm);margin-block-start:var(--space-xs)}#form-content input[type=checkbox]{margin-inline-end:var(--space-sm)}.preparation-reunions{max-inline-size:var(--container-xl);margin-inline:auto;padding:var(--space-sm) var(--space-md);padding-block-end:var(--space-xl);container-type:inline-size;container-name:page}.preparation-reunions h1{margin-block:var(--space-md);font-size:var(--font-size-2xl);color:var(--color-primary);font-weight:var(--font-weight-bold);text-align:center;background:var(--gradient-primary);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.preparation-reunions h2{margin-block:var(--space-lg) var(--space-sm);font-size:var(--font-size-lg);color:var(--color-primary-dark);font-weight:var(--font-weight-semibold);display:flex;align-items:center;gap:var(--space-sm);padding:var(--space-sm) var(--space-md);background:var(--color-secondary);border-radius:var(--radius-md);border-inline-start:4px solid var(--color-primary)}.preparation-reunions h2:before{content:"";inline-size:6px;block-size:6px;background:var(--color-primary);border-radius:var(--radius-full)}.meeting-controls{display:flex;flex-direction:column;gap:var(--space-sm);margin-block-end:var(--space-md);background:linear-gradient(135deg,var(--color-surface) 0%,var(--color-secondary) 100%);padding:var(--space-md);border-radius:var(--radius-lg);box-shadow:var(--shadow-md);border:2px solid var(--color-primary);position:relative;overflow:hidden}.meeting-controls:before{content:"";position:absolute;inset-block-start:0;inset-inline-start:0;inline-size:100%;block-size:4px;background:var(--gradient-primary)}.date-navigation{inline-size:100%}.date-navigation label{display:block;font-size:var(--font-size-xs);font-weight:var(--font-weight-semibold);color:var(--color-primary);margin-block-end:var(--space-xs);text-transform:uppercase;letter-spacing:.05em}.date-navigation select{inline-size:100%;padding:var(--space-sm) var(--space-md);border:2px solid var(--color-primary);border-radius:var(--radius-md);font-size:var(--font-size-base);font-weight:var(--font-weight-semibold);color:var(--color-primary);background:#fff;cursor:pointer;transition:all var(--transition-base);appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%230f7a5a' d='M6 9L1 4h10z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right var(--space-sm) center;padding-inline-end:var(--space-xl);box-shadow:var(--shadow-sm)}.date-navigation select:hover{border-color:var(--color-primary-light);box-shadow:0 0 0 3px #0f7a5a1a}.date-navigation select:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px #0f7a5a26}.meeting-actions{display:flex;flex-wrap:wrap;gap:var(--space-sm);justify-content:stretch}.meeting-actions button{flex:1 1 auto;min-inline-size:100px;font-size:var(--font-size-sm);padding:var(--space-sm) var(--space-sm);font-weight:var(--font-weight-bold);white-space:normal;word-break:break-word;box-shadow:var(--shadow-md);transition:all var(--transition-base)}.meeting-actions button:hover{transform:translateY(-2px);box-shadow:var(--shadow-lg)}.form-layout{display:grid;gap:var(--space-md);background:var(--color-surface);padding:var(--space-md);border-radius:var(--radius-lg);box-shadow:var(--shadow-md);border:2px solid var(--color-border)}.form-layout label{font-weight:var(--font-weight-semibold);display:block;margin-block-end:var(--space-xs);font-size:var(--font-size-sm);color:var(--color-text);letter-spacing:.01em}.form-layout input[type=text],.form-layout input[type=date],.form-layout input[type=time],.form-layout select,.form-layout textarea{inline-size:100%;border:2px solid var(--color-border);border-radius:var(--radius-md);font-size:var(--font-size-base);font-family:inherit;color:var(--color-text);background:var(--color-surface);transition:all var(--transition-base);line-height:var(--line-height-normal)}.form-layout input[type=text]:hover,.form-layout input[type=date]:hover,.form-layout input[type=time]:hover,.form-layout select:hover,.form-layout textarea:hover{border-color:var(--color-primary-light)}.form-layout input[type=text]:focus,.form-layout input[type=date]:focus,.form-layout input[type=time]:focus,.form-layout select:focus,.form-layout textarea:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px #0f7a5a26}.form-layout textarea{resize:vertical;min-block-size:100px;font-family:inherit}.form-row{display:flex;flex-direction:column;gap:var(--space-sm)}.form-group{display:flex;flex-direction:column;gap:var(--space-xs)}.form-group--checkbox{flex-direction:row;align-items:center;gap:var(--space-sm);padding:var(--space-sm);background:var(--color-secondary);border-radius:var(--radius-md)}.form-group--checkbox input[type=checkbox]{inline-size:1.25rem;block-size:1.25rem;cursor:pointer;accent-color:var(--color-primary)}.label--checkbox{display:flex;align-items:center;gap:var(--space-sm);font-weight:var(--font-weight-normal);margin:0;cursor:pointer;user-select:none}.honor-textarea{inline-size:100%;padding:var(--space-sm) var(--space-md);border:2px solid var(--color-border);border-radius:var(--radius-md);font-size:var(--font-size-base);font-family:inherit;color:var(--color-text);background:var(--color-surface);transition:all var(--transition-base);line-height:var(--line-height-normal);resize:vertical;min-block-size:80px}.honor-textarea:hover{border-color:var(--color-primary-light)}.honor-textarea:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px #0f7a5a26}.honor-textarea::placeholder{color:var(--color-text-muted);font-style:italic}.activities-grid{margin-block-start:var(--space-md);border-radius:var(--radius-lg);overflow:hidden;background:var(--color-surface);box-shadow:var(--shadow-lg);border:2px solid var(--color-primary);container-type:inline-size;container-name:activities}.activities-grid__header{display:none;grid-template-columns:160px 1fr;gap:var(--space-md);background:var(--gradient-primary);color:#fff;padding:var(--space-sm) var(--space-md);font-weight:var(--font-weight-bold);font-size:var(--font-size-xs);text-transform:uppercase;letter-spacing:.1em}.activities-grid__header-cell{padding:var(--space-xs)}.activities-grid__body{display:flex;flex-direction:column}.activity-row{display:flex;flex-direction:column;gap:var(--space-sm);padding:var(--space-md);border-block-start:2px solid var(--color-border-light);background:var(--color-surface);transition:all var(--transition-base);position:relative}.activity-row:first-child{border-block-start:none}.activity-row:hover{background:var(--color-secondary);transform:scale(1.01);box-shadow:inset 0 0 0 2px var(--color-primary-light)}.activity-row[data-default=true]{opacity:.6;background:repeating-linear-gradient(-45deg,var(--color-surface),var(--color-surface) 8px,rgba(15,122,90,.03) 8px,rgba(15,122,90,.03) 16px)}.activity-row[data-default=true]:before{content:"";position:absolute;inset-inline-start:0;inset-block:0;inline-size:3px;background:var(--color-warning);opacity:.5}@media(max-width:767px){.activity-row__time:before{content:"Heure & Durée";display:block;font-size:var(--font-size-xs);font-weight:var(--font-weight-bold);color:var(--color-primary);margin-block-end:var(--space-xs);text-transform:uppercase;letter-spacing:.05em}.activity-row__activity:before{content:"Activité";display:block;font-size:var(--font-size-xs);font-weight:var(--font-weight-bold);color:var(--color-primary);margin-block-end:var(--space-xs);text-transform:uppercase;letter-spacing:.05em}.activity-row__responsable:before{content:"Responsable";display:block;font-size:var(--font-size-xs);font-weight:var(--font-weight-bold);color:var(--color-primary);margin-block-end:var(--space-xs);text-transform:uppercase;letter-spacing:.05em}.activity-row__materiel:before{content:"Matériel";display:block;font-size:var(--font-size-xs);font-weight:var(--font-weight-bold);color:var(--color-primary);margin-block-end:var(--space-xs);text-transform:uppercase;letter-spacing:.05em}}.activity-row__time{display:flex;gap:var(--space-xs);align-items:stretch;background:var(--color-secondary);padding:var(--space-sm);border-radius:var(--radius-md);border:2px solid var(--color-primary);flex-wrap:wrap;min-inline-size:0}.activity-row__time input{flex:1 1 auto;min-inline-size:80px;padding:var(--space-sm);border:none;border-radius:var(--radius-sm);font-size:var(--font-size-base);font-weight:var(--font-weight-bold);text-align:center;background:#fff;transition:all var(--transition-base);color:var(--color-primary)}.activity-row__time .activity-time{flex:1 1 100px;min-inline-size:80px}.activity-row__time .activity-duration{flex:1 1 70px;min-inline-size:70px}.activity-row__time input[type=time]{font-variant-numeric:tabular-nums}.activity-row__time input:hover{border-color:var(--color-primary-light);box-shadow:0 2px 8px #0f7a5a1a}.activity-row__time input:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px #0f7a5a26}.activity-row__activity{display:flex;gap:var(--space-sm);align-items:stretch;flex-wrap:wrap;min-inline-size:0}.activity-row__activity select,.activity-row__activity input,.activity-select,.activity-input{flex:1 1 auto;min-inline-size:120px;padding:var(--space-sm);border:2px solid var(--color-border);border-radius:var(--radius-sm);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);background:var(--color-surface);transition:all var(--transition-base);color:var(--color-text)}.activity-row__activity select:hover,.activity-row__activity input:hover{border-color:var(--color-primary-light);box-shadow:0 2px 8px #0f7a5a1a}.activity-row__activity select:focus,.activity-row__activity input:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px #0f7a5a26}.edit-activity-btn,.description-btn{inline-size:var(--touch-target-min);block-size:var(--touch-target-min);padding:0;border:2px solid var(--color-border);border-radius:var(--radius-md);background:var(--color-surface);color:var(--color-primary);font-size:var(--font-size-lg);font-weight:var(--font-weight-bold);cursor:pointer;transition:all var(--transition-base);display:inline-flex;align-items:center;justify-content:center;flex-shrink:0}.edit-activity-btn:hover,.description-btn:hover{background:var(--color-primary);color:#fff;border-color:var(--color-primary);transform:translateY(-2px);box-shadow:var(--shadow-md)}.edit-activity-btn:active,.description-btn:active{transform:translateY(0)}.activity-row__responsable select,.activity-row__responsable input,.activity-responsable,.responsable-input{inline-size:100%;min-inline-size:100px;padding:var(--space-sm);border:2px solid var(--color-border);border-radius:var(--radius-sm);font-size:var(--font-size-sm);background:var(--color-surface);transition:all var(--transition-base)}.activity-row__responsable select:hover,.activity-row__responsable input:hover{border-color:var(--color-primary-light);box-shadow:0 2px 8px #0f7a5a1a}.activity-row__responsable select:focus,.activity-row__responsable input:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px #0f7a5a26}.activity-row__materiel input,.activity-materiel{inline-size:100%;min-inline-size:100px;padding:var(--space-sm);border:2px solid var(--color-border);border-radius:var(--radius-sm);font-size:var(--font-size-sm);background:var(--color-surface);transition:all var(--transition-base)}.activity-row__materiel input:hover{border-color:var(--color-primary-light);box-shadow:0 2px 8px #0f7a5a1a}.activity-row__materiel input:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px #0f7a5a26}.activity-row__actions{display:flex;gap:var(--space-sm);justify-content:flex-start;flex-wrap:wrap;padding-block-start:var(--space-sm);border-block-start:1px solid var(--color-border-light)}.activity-row__actions button{padding:var(--space-sm) var(--space-md);font-size:var(--font-size-sm);min-block-size:var(--touch-target-min);font-weight:var(--font-weight-medium);border-radius:var(--radius-md);transition:all var(--transition-base)}.add-row-btn{background:var(--color-success);color:#fff;border:none}.add-row-btn:hover{background:var(--color-success-light);transform:translateY(-2px);box-shadow:var(--shadow-md)}.delete-row-btn{background:var(--color-error);color:#fff;border:none}.delete-row-btn:hover{background:var(--color-error-light);transform:translateY(-2px);box-shadow:var(--shadow-md)}.hidden{display:none!important}.form-actions,.form-actions--mobile{display:flex;flex-direction:column;gap:var(--space-sm);margin-block-start:var(--space-md);padding:var(--space-md);background:linear-gradient(135deg,var(--color-surface) 0%,var(--color-secondary) 100%);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);border:2px solid var(--color-primary);position:sticky;bottom:var(--space-sm);z-index:var(--z-sticky)}.form-actions button{inline-size:100%;padding:var(--space-md) var(--space-lg);min-block-size:var(--touch-target-min);font-size:var(--font-size-base);font-weight:var(--font-weight-semibold);border-radius:var(--radius-md);transition:all var(--transition-base)}.modal{display:none;position:fixed;z-index:var(--z-modal);inset:0;background-color:#1d2f2abf;backdrop-filter:blur(4px);padding:var(--space-md);animation:fadeIn var(--transition-base)}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modal.show{display:flex;align-items:center;justify-content:center}.modal-content{background:var(--color-surface);padding:var(--space-xl) var(--space-lg);border-radius:var(--radius-xl);inline-size:100%;max-inline-size:540px;max-block-size:90vh;overflow-y:auto;box-shadow:var(--shadow-xl);border:1px solid var(--color-border-light);animation:slideUp var(--transition-base)}@keyframes slideUp{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}.modal-header{display:flex;justify-content:space-between;align-items:flex-start;margin-block-end:var(--space-lg);padding-block-end:var(--space-md);border-block-end:2px solid var(--color-border-light)}.modal-header h2{margin:0;font-size:var(--font-size-xl);color:var(--color-primary);font-weight:var(--font-weight-bold)}.modal-header h2:before{display:none}.modal-close{background:var(--color-secondary);border:2px solid var(--color-border);inline-size:var(--touch-target-min);block-size:var(--touch-target-min);border-radius:var(--radius-full);font-size:var(--font-size-xl);cursor:pointer;color:var(--color-text);transition:all var(--transition-base);display:flex;align-items:center;justify-content:center;flex-shrink:0}.modal-close:hover{background:var(--color-error);color:#fff;border-color:var(--color-error);transform:rotate(90deg)}.modal-actions{display:flex;gap:var(--space-md);margin-block-start:var(--space-xl);justify-content:flex-end;flex-wrap:wrap}.modal-actions button{padding:var(--space-md) var(--space-xl);min-block-size:var(--touch-target-min);font-weight:var(--font-weight-semibold);border-radius:var(--radius-md);flex:1;min-inline-size:120px}.sr-only{position:absolute;inline-size:1px;block-size:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}.footer-nav{margin-block-start:var(--space-3xl);text-align:center;padding:var(--space-lg)}.footer-nav a{color:var(--color-primary);text-decoration:none;font-weight:var(--font-weight-medium);padding:var(--space-sm) var(--space-md);border-radius:var(--radius-md);transition:all var(--transition-base);display:inline-block}.footer-nav a:hover{background:var(--color-secondary);transform:translateY(-2px)}@container page (min-width: 520px){.preparation-reunions{padding:var(--space-md) var(--space-lg)}.meeting-controls{flex-direction:row;gap:var(--space-md);align-items:flex-end;padding:var(--space-md)}.date-navigation{flex:1;min-inline-size:240px}.meeting-actions{flex:2;gap:var(--space-md);justify-content:flex-end}.meeting-actions button{flex:0 1 auto;min-inline-size:auto}}@container page (min-width: 600px){.preparation-reunions h1{font-size:var(--font-size-3xl)}.form-layout{padding:var(--space-md) var(--space-lg)}.form-row{flex-direction:row;gap:var(--space-md)}.form-group{flex:1}.form-actions{flex-direction:row;gap:var(--space-md);position:static;padding:var(--space-lg)}.form-actions button{inline-size:auto;flex:1}.modal-content{inline-size:90%;max-inline-size:640px}}@container activities (min-width: 620px){.activity-row__time:before,.activity-row__activity:before,.activity-row__responsable:before,.activity-row__materiel:before{display:none}.activities-grid__header{display:grid;grid-template-columns:minmax(160px,180px) minmax(280px,1fr) minmax(140px,180px) minmax(140px,180px);gap:var(--space-sm);padding:var(--space-xs) var(--space-sm)}.activity-row{display:grid;grid-template-columns:minmax(160px,180px) minmax(280px,1fr) minmax(140px,180px) minmax(140px,180px);grid-template-rows:auto auto;gap:var(--space-sm);align-items:start;padding:var(--space-sm)}.activity-row__time{grid-column:1;grid-row:1 / 3}.activity-row__activity{grid-column:2;grid-row:1;margin-block-end:0}.activity-row__responsable{grid-column:3;grid-row:1}.activity-row__materiel{grid-column:4;grid-row:1}.activity-row__actions{grid-column:2 / -1;grid-row:2;border-block-start:1px solid var(--color-border-light);padding-block-start:var(--space-xs);margin-block-start:var(--space-xs);justify-content:flex-end}}@container activities (min-width: 980px){.activities-grid__header{grid-template-columns:220px 1.4fr .9fr .9fr 120px;gap:var(--space-sm)}.activity-row{grid-template-columns:220px 1.4fr .9fr .9fr 120px;grid-template-rows:auto;gap:var(--space-sm)}.activity-row__time{grid-column:1;grid-row:1}.activity-row__activity{grid-column:2;grid-row:1}.activity-row__responsable{grid-column:3;grid-row:1}.activity-row__materiel{grid-column:4;grid-row:1}.activity-row__actions{grid-column:5;grid-row:1;padding-block-start:0;border-block-start:none;margin-block-start:0;justify-content:center;flex-direction:column;gap:var(--space-xs)}.activity-row__actions button{inline-size:100%}}.activity-widget{background-color:var(--color-secondary);padding:var(--space-lg);border:1px solid var(--color-border);margin-block:var(--space-2xl) var(--space-lg);border-radius:var(--radius-md);text-align:center;display:none;box-shadow:var(--shadow-base)}.activity-widget h3{margin:0;font-size:var(--font-size-xl);color:var(--color-primary)}.activity-widget p{margin:var(--space-sm) 0 0;font-size:var(--font-size-base);color:var(--color-text)}.upcoming-meeting{max-inline-size:var(--container-sm);margin-inline:auto;padding:var(--space-lg)}.meeting-details{display:flex;flex-wrap:wrap;gap:var(--space-lg)}.upcoming-meeting ul{list-style:none;padding-inline-start:0}.upcoming-meeting li{font-size:var(--font-size-lg);padding:var(--space-md) 0;border-block-end:1px solid var(--color-border)}.upcoming-meeting li:last-child{border-block-end:none}.upcoming-meeting .actions{display:flex;justify-content:space-around;flex-wrap:wrap;gap:var(--space-md);margin-block-start:var(--space-lg)}.upcoming-meeting .button{background-color:var(--color-primary);color:#fff;padding:var(--space-md) var(--space-lg);border-radius:var(--radius-md);text-decoration:none;font-size:var(--font-size-base);font-weight:var(--font-weight-medium);display:inline-block;text-align:center;min-inline-size:120px;transition:all var(--transition-base);box-shadow:var(--shadow-sm)}.upcoming-meeting .button:hover{background-color:var(--color-selected);transform:translateY(-2px);box-shadow:var(--shadow-md)}@media(width<=600px){.upcoming-meeting li{font-size:var(--font-size-xl);padding:var(--space-sm) 0}.upcoming-meeting .button{font-size:var(--font-size-sm);padding:var(--space-sm) var(--space-md);min-inline-size:100px}}.badge-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:var(--space-lg);margin-block-start:var(--space-lg)}.badge-item{border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--space-lg);text-align:center;background-color:var(--color-surface);transition:all var(--transition-base);box-shadow:var(--shadow-sm)}.badge-item:hover{transform:translateY(-4px);box-shadow:var(--shadow-md)}.badge-item img{block-size:150px;object-fit:contain;margin-block-end:var(--space-md);border:none}.badge-item h3{margin:var(--space-md) 0;font-size:var(--font-size-base);color:var(--color-primary)}.stars{font-size:var(--font-size-2xl);margin:var(--space-md) 0;color:gold}#honors-list input[type=checkbox]{position:absolute;inset-inline-start:-9999px}.page-header--compact{display:flex;align-items:center;gap:var(--space-md);margin-block-end:var(--space-md)}.page-header--compact h1{margin:0;flex:1}.date-navigation--inline{display:flex;align-items:center;gap:var(--space-sm);margin-block-end:var(--space-lg)}.date-navigation--inline label{margin:0;white-space:nowrap}.date-navigation--inline select{flex:1;max-inline-size:300px}.honors-table{margin-block-end:calc(7rem + var(--safe-area-bottom));background-color:#fff;border-radius:var(--radius-md);box-shadow:var(--shadow-sm);overflow:hidden}.honors-table__header{display:grid;grid-template-columns:3rem 1fr 6rem 10rem 3rem;gap:var(--space-md);padding:var(--space-md) var(--space-lg);background-color:var(--color-primary);color:#fff;font-weight:var(--font-weight-semibold);font-size:var(--font-size-sm);text-transform:uppercase;letter-spacing:.5px;position:sticky;top:0;z-index:10}.honors-table__header-cell{display:flex;align-items:center;gap:var(--space-xs);padding:var(--space-xs)}.honors-table__header-cell[data-sort]{cursor:pointer;user-select:none;transition:background-color var(--transition-base);border-radius:var(--radius-sm);padding:var(--space-xs) var(--space-sm)}.honors-table__header-cell[data-sort]:hover{background-color:#ffffff26}.honors-table__header-cell[data-sort]:active{background-color:#ffffff40}.honors-table__header-cell--checkbox{grid-column:1;justify-content:center}.honors-table__header-cell--name{grid-column:2}.honors-table__header-cell--count{grid-column:3;justify-content:flex-end}.honors-table__header-cell--date{grid-column:4;justify-content:flex-end}.sort-indicator{font-size:var(--font-size-sm);opacity:.9;margin-inline-start:var(--space-xs)}.honors-table__row{display:grid;grid-template-columns:3rem 1fr 6rem 10rem 3rem;gap:var(--space-md);padding:var(--space-lg);border-block-end:1px solid var(--color-border);cursor:pointer;transition:all var(--transition-base);align-items:center;background-color:#fff;position:relative}.honors-table__row:nth-child(2n){background-color:#f8f9fa}.honors-table__row:hover{background-color:var(--color-primary-light);color:#fff;transform:translate(2px);box-shadow:var(--shadow-sm)}.honors-table__row.selected{background-color:var(--color-selected);color:var(--color-selected-text);font-weight:var(--font-weight-semibold)}.honors-table__row.menu-open{z-index:var(--z-overlay)}.honors-table__row.disabled{cursor:not-allowed;background-color:#e9f3ef;color:var(--color-text-muted)}.honors-table__row.disabled:hover{transform:none;box-shadow:none}.honors-table__cell{display:flex;align-items:center}.honors-table__cell--checkbox{grid-column:1;justify-content:center}.honors-table__cell--checkbox input[type=checkbox]{position:static;inline-size:1.25rem;block-size:1.25rem;cursor:pointer;margin:0;pointer-events:none}.honors-table__cell--name{grid-column:2;font-size:var(--font-size-base);font-weight:var(--font-weight-medium)}.honors-table__cell--name label{cursor:pointer;margin:0;pointer-events:none;display:flex;flex-direction:column;gap:var(--space-xs)}.participant-name{font-weight:var(--font-weight-medium)}.participant-reason{font-size:var(--font-size-xs);color:var(--color-text-primary);font-weight:var(--font-weight-normal);font-style:italic;display:block}.participant-last-honor{font-size:var(--font-size-xs);color:var(--color-text-light);font-weight:var(--font-weight-normal);display:none}.honors-table__row:hover .participant-reason,.honors-table__row:hover .participant-last-honor,.honors-table__row.selected .participant-reason,.honors-table__row.selected .participant-last-honor{color:var(--color-text-primary)}.honors-table__cell--count{grid-column:3;justify-content:flex-end;font-size:var(--font-size-xl);font-weight:var(--font-weight-bold);color:var(--color-primary)}.honors-table__row:hover .honors-table__cell--count,.honors-table__row.selected .honors-table__cell--count{color:inherit}.honors-table__cell--date{grid-column:4;justify-content:flex-end;font-size:var(--font-size-sm);color:var(--color-text-light);font-weight:var(--font-weight-normal)}.honors-table__row:hover .honors-table__cell--date,.honors-table__row.selected .honors-table__cell--date{color:inherit}@media(max-width:768px){.honors-table__header,.honors-table__row{grid-template-columns:2.5rem 1fr 5rem 9rem 3rem;gap:var(--space-sm);padding:var(--space-md)}.honors-table__header{font-size:.7rem}.honors-table__cell--count{font-size:var(--font-size-lg)}.honors-table__cell--name,.honors-table__cell--date{font-size:var(--font-size-sm)}}@media(max-width:480px){.honors-table__header,.honors-table__row{grid-template-columns:2.5rem 1fr 4rem 3rem;gap:var(--space-sm)}.honors-table__header-cell--date,.honors-table__cell--date{display:none}.participant-reason,.participant-last-honor{display:block}}.honors-table__cell--actions{grid-column:5;justify-content:center;position:relative;pointer-events:all;z-index:1}.honor-actions{position:relative;display:inline-block;pointer-events:all}.honor-actions__trigger{background:none;border:1px solid var(--color-border);font-size:1.5rem;line-height:1;padding:var(--space-xs) var(--space-sm);cursor:pointer;color:var(--color-primary);border-radius:var(--radius-sm);transition:all var(--transition-base);pointer-events:all;user-select:none;-webkit-user-select:none;touch-action:manipulation;-webkit-tap-highlight-color:transparent;min-width:44px;min-height:44px;display:flex;align-items:center;justify-content:center}.honor-actions__trigger:hover{background-color:var(--color-primary-light);color:#fff;border-color:var(--color-primary)}.honor-actions__trigger:active{background-color:var(--color-primary);transform:scale(.95)}.honors-table__row:hover .honor-actions__trigger{background-color:#fff3;color:#fff;border-color:#fff6}.honors-table__row:hover .honor-actions__trigger:hover{background-color:#ffffff4d;color:#fff;border-color:#fff}.honor-actions__menu{position:absolute;top:100%;right:0;background:#fff;border-radius:var(--radius-md);box-shadow:0 4px 20px #0000004d;min-width:200px;padding:var(--space-xs);z-index:1000;display:none;margin-top:var(--space-xs);border:1px solid var(--color-border)}.honor-actions__menu.show{display:block;animation:slideDown .2s ease-out}@keyframes slideDown{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.honor-actions__item{display:flex;align-items:center;gap:var(--space-sm);width:100%;padding:var(--space-sm) var(--space-md);border:none;background:none;text-align:left;cursor:pointer;border-radius:var(--radius-sm);transition:background-color var(--transition-base);font-size:var(--font-size-sm);color:var(--color-text);white-space:nowrap;touch-action:manipulation;user-select:none;-webkit-user-select:none;-webkit-tap-highlight-color:transparent}.honor-actions__item:hover{background-color:var(--color-primary-light);color:#fff}.honor-actions__item:active{background-color:var(--color-primary)}.honor-actions__item--danger{color:var(--color-error)}.honor-actions__item--danger:hover{background-color:var(--color-error);color:#fff}.honor-actions__item--undo{color:var(--color-warning);font-weight:var(--font-weight-semibold)}.honor-actions__item--undo:hover{background-color:var(--color-warning);color:#fff}@media(max-width:768px){.honor-actions__menu{right:auto;left:50%;transform:translate(-50%)}.honor-actions__item{padding:var(--space-md);font-size:var(--font-size-base);min-height:44px}}@media(max-width:480px){.honors-table__cell--actions{grid-column:4}}.warning-text{background-color:#fff3cd;border:1px solid #ffc107;border-radius:var(--radius-sm);padding:var(--space-sm) var(--space-md);margin-bottom:var(--space-md);color:#856404;font-size:var(--font-size-sm);line-height:1.5}.modal-overlay{position:fixed;inset:0;background-color:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:var(--space-md)}.modal-dialog{background-color:#fff;border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);max-width:500px;width:100%;max-height:90vh;overflow-y:auto;animation:modalSlideIn .3s ease-out}@keyframes modalSlideIn{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-lg);border-bottom:1px solid var(--color-border)}.modal-header h2{margin:0;font-size:var(--font-size-xl);font-weight:var(--font-weight-semibold);color:var(--color-primary)}.modal-close{background:none;border:none;font-size:1.5rem;color:var(--color-text-light);cursor:pointer;padding:var(--space-xs);line-height:1;transition:color var(--transition-base)}.modal-close:hover{color:var(--color-primary)}.modal-body{padding:var(--space-lg)}.modal-participant-name{font-size:var(--font-size-lg);font-weight:var(--font-weight-semibold);color:var(--color-primary);margin-bottom:var(--space-sm)}.modal-progress{font-size:var(--font-size-sm);color:var(--color-text-light);margin-bottom:var(--space-lg)}.modal-actions{display:flex;gap:var(--space-md);justify-content:flex-end;margin-top:var(--space-lg)}.modal-actions .button{min-width:100px}.guest-entry{margin-block-start:var(--space-lg);padding:var(--space-md);background-color:var(--color-secondary);border-radius:var(--radius-md);border:1px solid var(--color-border)}.guest-row{display:flex;justify-content:space-between;padding:var(--space-sm) 0;border-block-end:1px solid var(--color-border)}.guest-row:last-child{border-block-end:none}.guest-name{font-weight:var(--font-weight-semibold);color:var(--color-primary)}.guest-email{color:var(--color-text-light)}.guest-date{color:var(--color-text-muted);font-size:var(--font-size-sm)}.child-card{border:1px solid var(--color-border-light);border-radius:var(--radius-md);padding:var(--space-md);margin-block-end:var(--space-md);background-color:var(--color-surface)}.child-name{font-weight:var(--font-weight-bold);margin-block-end:var(--space-sm);color:var(--color-primary);font-size:var(--font-size-lg)}.contact-info{margin-inline-start:var(--space-md);margin-block-end:var(--space-sm);line-height:var(--line-height-relaxed)}.emergency-contact{color:var(--color-error);font-weight:var(--font-weight-bold);margin-inline-start:var(--space-sm);background-color:#fff3cd;padding:var(--space-xs) var(--space-sm);border-radius:var(--radius-sm);display:inline-block}.phone-number{display:block;margin-inline-start:var(--space-md);font-family:monospace;color:var(--color-text)}.participant-documents{display:flex;flex-direction:column;gap:var(--space-md)}.document-link{display:block;margin:var(--space-sm) 0}.document-link a{color:var(--color-info);text-decoration:underline;transition:color var(--transition-fast)}.document-link a:hover{color:var(--color-primary)}.fixed-header,.fixed-footer{position:fixed;inset-inline:0;background-color:var(--color-surface);z-index:var(--z-fixed);padding:var(--space-sm);box-shadow:var(--shadow-sm)}.fixed-header{inset-block-start:0;padding-block-start:calc(var(--space-sm) + var(--safe-area-top))}.fixed-footer{inset-block-end:0;padding-block-end:calc(var(--space-sm) + var(--safe-area-bottom));display:flex;gap:var(--space-sm);justify-content:space-around}.group-card{background-color:var(--color-secondary);border-radius:var(--radius-lg);padding:var(--space-md);margin-block-end:var(--space-lg);box-shadow:var(--shadow-sm)}.group-card h3{margin-block-start:0;margin-block-end:var(--space-md);font-size:var(--font-size-lg);color:var(--color-primary)}.status-btn{padding:var(--space-md);border:none;border-radius:var(--radius-md);color:#fff;font-weight:var(--font-weight-bold);cursor:pointer;transition:all var(--transition-fast);min-inline-size:var(--touch-target-min);min-block-size:var(--touch-target-min)}.status-btn.present{background-color:var(--color-success-light)}.status-btn.absent{background-color:var(--color-error-light)}.status-btn.late{background-color:var(--color-warning-light)}.status-btn.excused{background-color:var(--color-info)}.status-btn:hover{transform:translateY(-2px);box-shadow:var(--shadow-md)}#description-text{font-size:var(--font-size-base);color:var(--color-text);line-height:var(--line-height-relaxed)}details summary{cursor:pointer;font-weight:var(--font-weight-bold);margin-block-start:var(--space-md);color:var(--color-primary);padding:var(--space-sm);border-radius:var(--radius-sm);transition:background-color var(--transition-fast)}details summary:hover{background-color:var(--color-secondary)}details p{margin:var(--space-sm) 0;text-align:start;padding-inline-start:var(--space-md)}.attendance-container{max-inline-size:var(--container-sm);margin-inline:auto;padding:var(--space-md)}.date-select{flex:1;margin-inline:var(--space-md);padding:var(--space-sm);font-size:var(--font-size-sm);border:1px solid var(--color-primary);border-radius:var(--radius-sm)}@media(width<=480px){.nav-btn,.date-navigation button{padding:var(--space-xs) var(--space-sm);font-size:var(--font-size-sm)}.date-select{font-size:var(--font-size-xs)}.group-card h3{font-size:var(--font-size-base)}.participant-row,.name-item{font-size:var(--font-size-sm)}.status-btn{font-size:var(--font-size-sm);padding:var(--space-sm)}}.badge-dashboard{display:flex;flex-direction:column;gap:var(--space-lg);padding:var(--space-lg)}.badge-dashboard__header{display:flex;justify-content:space-between;gap:var(--space-md);align-items:center;flex-wrap:wrap}.badge-dashboard__actions{display:flex;gap:var(--space-sm);align-items:center}.badge-dashboard__stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:var(--space-md)}.stat-card{background:var(--color-surface);border:1px solid var(--color-border-light);border-radius:var(--radius-md);padding:var(--space-md);box-shadow:var(--shadow-sm)}.stat-card__label{color:var(--color-text-muted);font-size:var(--font-size-sm)}.stat-card__value{font-size:var(--font-size-2xl);font-weight:var(--font-weight-bold)}.badge-dashboard__controls{display:flex;align-items:center;gap:var(--space-sm)}.badge-table{background:var(--color-surface);border:1px solid var(--color-border-light);border-radius:var(--radius-md);overflow:hidden;box-shadow:var(--shadow-sm)}.badge-table__header,.badge-table__row{display:grid;grid-template-columns:auto 1fr;gap:var(--space-sm);padding:var(--space-xs) var(--space-md);align-items:flex-start}@media(max-width:768px){.badge-table__header,.badge-table__row{grid-template-columns:1fr;gap:var(--space-xs)}.badge-table__header span:not(:first-child){display:none}.participant-header{min-width:100%}.badge-table__cell--badges{flex-direction:column}.badge-chip,.badge-chip-compact{min-width:100%}.badge-chip-compact{padding:var(--space-sm)}}.badge-table__group{background:#eef2ff;border-block-start:1px solid var(--color-border-light);border-block-end:1px solid var(--color-border-light);padding:var(--space-xs) var(--space-md)}.badge-table__group-title{font-weight:var(--font-weight-semibold);color:var(--color-primary-dark)}.badge-table__header{background:var(--color-secondary);font-weight:var(--font-weight-semibold);color:var(--color-text-muted)}.badge-table__row:nth-of-type(odd){background:#fafafa}.badge-table__cell{font-size:var(--font-size-sm)}.badge-table__cell--actions{display:flex;gap:var(--space-sm);justify-content:flex-end;align-items:center}.badge-table__row .participant-header{display:flex;justify-content:space-between;align-items:center;gap:var(--space-sm);min-width:180px;padding-right:var(--space-sm)}.badge-table__row .participant-info{display:flex;flex-direction:column;gap:2px}.badge-table__row .participant-name{font-weight:var(--font-weight-semibold);font-size:var(--font-size-base);line-height:1.3}.badge-table__row .participant-actions{display:flex;gap:var(--space-xs);align-items:center;flex-shrink:0}.star-count{font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);color:var(--color-text-muted);white-space:nowrap}.icon-button{padding:.35rem;border:1px solid var(--color-border-light);background:var(--color-surface);border-radius:var(--radius-sm);cursor:pointer;display:inline-flex;align-items:center;justify-content:center;transition:all .2s;color:var(--color-text-muted)}.icon-button:hover{background:var(--color-primary);color:#fff;border-color:var(--color-primary)}.icon-button svg{display:block}.badge-table__group-tag{display:inline-flex;padding:.15rem .45rem;background:var(--color-secondary);border-radius:var(--radius-full);font-size:var(--font-size-xs);color:var(--color-text-muted)}.badge-table__cell--badges{display:flex;flex-wrap:wrap;gap:var(--space-sm)}.badge-chip-compact{background:#f4f6fb;border:1px solid var(--color-border-light);border-radius:var(--radius-md);padding:var(--space-xs) var(--space-sm);min-width:140px;flex:0 1 auto;box-shadow:var(--shadow-sm);display:flex;gap:var(--space-xs);align-items:flex-start}.badge-chip-compact .badge-chip__image{width:72px;height:72px;object-fit:contain;flex-shrink:0;border-radius:var(--radius-xs)}.badge-chip-compact .badge-chip__content{flex:1;min-width:0;display:flex;flex-direction:column;gap:.35rem}.badge-chip-compact .badge-chip__name{font-weight:var(--font-weight-semibold);font-size:var(--font-size-sm);line-height:1.2}.badge-chip__stars-compact{display:flex;gap:.25rem;flex-wrap:wrap}.badge-chip__status{display:flex;gap:.35rem;flex-wrap:wrap;margin-top:-.1rem}.badge-chip__status .status-pill{padding:.15rem .4rem;font-size:var(--font-size-xs);font-weight:var(--font-weight-medium)}.progress-compact{width:100%;height:3px;background:var(--color-border-light);border-radius:var(--radius-full);overflow:hidden}.progress-compact .progress__bar{height:100%;background:var(--color-primary);border-radius:var(--radius-full);transition:width .3s}.badge-chip{background:#f4f6fb;border:1px solid var(--color-border-light);border-radius:var(--radius-md);padding:var(--space-sm);min-width:220px;flex:1 1 auto;box-shadow:var(--shadow-sm)}.badge-chip__header{display:flex;gap:var(--space-sm);align-items:flex-start}.badge-chip__image{width:48px;height:48px;object-fit:contain;flex-shrink:0;border-radius:var(--radius-sm)}.badge-chip__content{flex:1;min-width:0}.badge-chip__top{display:flex;justify-content:space-between;gap:var(--space-sm);align-items:baseline}.badge-chip__name{font-weight:var(--font-weight-semibold);font-size:var(--font-size-sm)}.badge-chip__stars{display:inline-flex;gap:.35rem;flex-shrink:0}.badge-chip__footer{display:flex;justify-content:space-between;gap:var(--space-sm);align-items:center;margin-top:var(--space-xs);flex-wrap:wrap}.badge-chip__actions{display:flex;gap:var(--space-xs)}.status-group{display:flex;gap:var(--space-xs);flex-wrap:wrap}.status-pill{display:inline-flex;align-items:center;gap:.25rem;padding:.25rem .5rem;border-radius:var(--radius-full);font-size:var(--font-size-xs);background:var(--color-secondary);color:var(--color-text);border:1px solid var(--color-border-light)}.status-pill--approved{background:#e6f4ea;color:#1f7a36}.status-pill--pending{background:#fff7e6;color:#8a5b00}.status-pill--rejected{background:#fdecea;color:#8a1f1f}.badge-chip--muted{background:var(--color-secondary);color:var(--color-text-muted);min-width:140px}.badge-star-button{border:1px solid var(--color-border-light);background:var(--color-surface);border-radius:var(--radius-full);width:1.5rem;height:1.5rem;display:inline-flex;align-items:center;justify-content:center;font-size:.875rem;cursor:pointer;transition:transform var(--transition-fast),box-shadow var(--transition-fast)}.badge-star-button.is-earned{color:#f4b400;box-shadow:var(--shadow-sm)}.badge-star-button.is-earned:hover,.badge-star-button.is-earned:focus-visible{transform:scale(1.05);outline:2px solid var(--color-primary);outline-offset:2px}.badge-star-button.is-locked{color:var(--color-text-muted);background:var(--color-secondary);cursor:not-allowed}.badge-table__cell--actions .text-button{white-space:nowrap}.progress{width:100%;background:var(--color-border-light);border-radius:var(--radius-full);height:8px;overflow:hidden;margin-top:var(--space-xs)}.progress__bar{background:var(--color-primary);height:100%}.badge-dashboard__modal{position:fixed;inset:0;display:grid;place-items:center;z-index:var(--z-modal)}.badge-dashboard__modal .modal{display:block;position:relative}.modal__backdrop{position:absolute;inset:0;background:#00000080}.badge-dashboard__modal .modal,.modal-screen .modal,.modal-container .modal{display:block;position:relative;background:var(--color-surface);border-radius:var(--radius-lg);padding:var(--space-lg);max-width:720px;width:min(720px,96vw);max-height:90vh;overflow-y:auto;box-shadow:var(--shadow-lg);z-index:var(--z-modal)}.modal__header{display:flex;justify-content:space-between;gap:var(--space-md);align-items:flex-start}.modal__header-actions{display:flex;align-items:center;gap:var(--space-xs)}.modal-screen{position:fixed;inset:0;display:grid;place-items:center;background:#00000073;padding:var(--space-md);z-index:var(--z-modal)}.modal-screen .modal{display:block;position:relative}.statement-summary{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:var(--space-sm);margin:var(--space-md) 0}.statement-summary div{background:var(--color-secondary);padding:var(--space-sm);border-radius:var(--radius-md);display:flex;flex-direction:column;gap:var(--space-xs)}.statement-lines{display:flex;flex-direction:column;gap:var(--space-sm)}.statement-line{border:1px solid var(--color-border-light);border-radius:var(--radius-md);padding:var(--space-sm);background:var(--color-surface);display:flex;flex-direction:column;gap:var(--space-xs)}.statement-amounts{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:var(--space-xs)}.text-warning{color:var(--color-warning);font-weight:var(--font-weight-semibold)}.text-success{color:var(--color-success);font-weight:var(--font-weight-semibold)}.modal__content{display:grid;gap:var(--space-md);margin-top:var(--space-md)}.modal__section{display:grid;gap:var(--space-sm)}.modal__actions{display:flex;align-items:center;justify-content:flex-end;gap:var(--space-md);margin-top:var(--space-lg);padding-top:var(--space-md);border-top:1px solid var(--color-border)}.modal-container{position:fixed;inset:0;z-index:var(--z-modal);align-items:center;justify-content:center;padding:var(--space-md)}.modal-container--visible{display:flex}.modal-container .modal__backdrop{position:fixed;inset:0;background:#00000080;z-index:-1}.badge-history{list-style:none;display:grid;gap:var(--space-sm)}.badge-history__row{display:flex;justify-content:space-between;gap:var(--space-sm);align-items:baseline}.badge-history__title{font-weight:var(--font-weight-semibold)}.badge-history__meta{color:var(--color-text-muted);font-size:var(--font-size-xs)}.badge-history__text{font-size:var(--font-size-sm)}.badge-history__text.muted{color:var(--color-text-muted)}.badge-history__stars{font-weight:var(--font-weight-semibold)}.form-actions{display:flex;justify-content:flex-end}.badge-dashboard textarea,.badge-dashboard select,.badge-dashboard input[type=number],.badge-dashboard input[type=date]{width:100%;padding:var(--space-sm);border-radius:var(--radius-sm);border:1px solid var(--color-border);font-size:var(--font-size-sm)}.modal__tabs{display:flex;gap:0;border-bottom:2px solid var(--color-border);margin:0 calc(var(--space-md) * -1);padding:0 var(--space-md)}.tab-button{flex:1;background:none;border:none;padding:var(--space-sm) var(--space-md);cursor:pointer;font-weight:var(--font-weight-medium);color:var(--color-text-muted);border-bottom:2px solid transparent;margin-bottom:-2px;transition:color .2s,border-color .2s}.tab-button:hover{color:var(--color-text-primary)}.tab-button.active{color:var(--color-primary);border-bottom-color:var(--color-primary)}.tab-content.active{display:block}.form-group-compact{display:flex;flex-direction:column;gap:var(--space-xs);margin-bottom:var(--space-sm)}.form-group-compact label{font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--color-text-secondary)}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-sm)}.badge-history-toggle{margin:var(--space-sm) 0;border:1px solid var(--color-border);border-radius:var(--radius-sm);padding:var(--space-xs)}.badge-history-toggle summary{cursor:pointer;font-weight:var(--font-weight-medium);font-size:var(--font-size-sm);padding:var(--space-xs);user-select:none}.badge-history-toggle summary:hover{color:var(--color-primary)}.badge-history-compact{list-style:none;padding:0;margin-top:var(--space-xs)}.badge-history-compact li{display:grid;grid-template-columns:auto 1fr auto;gap:var(--space-xs);align-items:center;padding:var(--space-xs);border-top:1px solid var(--color-border-light);font-size:var(--font-size-sm)}.badge-history-compact li:first-child{border-top:none}.badge-hist-status{display:inline-block;padding:2px 6px;border-radius:var(--radius-xs);background:var(--color-bg-secondary);font-size:var(--font-size-xs);font-weight:var(--font-weight-semibold);text-transform:uppercase}.badge-hist-date{color:var(--color-text-muted);font-size:var(--font-size-xs)}.badge-hist-stars{font-weight:var(--font-weight-semibold)}.badge-hist-text{grid-column:1 / -1;margin:var(--space-xs) 0 0 0;padding-top:var(--space-xs);border-top:1px dotted var(--color-border-light);color:var(--color-text-muted);font-size:var(--font-size-xs)}.feedback-success{color:var(--color-success, #22c55e);font-size:var(--font-size-sm);padding:var(--space-xs);background:var(--color-success-bg, #f0fdf4);border-radius:var(--radius-sm);margin-top:var(--space-xs)}.feedback-error{color:var(--color-error, #ef4444);font-size:var(--font-size-sm);padding:var(--space-xs);background:var(--color-error-bg, #fef2f2);border-radius:var(--radius-sm);margin-top:var(--space-xs)}.reports-header{display:grid;gap:var(--space-sm);margin-bottom:var(--space-lg)}.reports-kicker{text-transform:uppercase;letter-spacing:.04em;color:var(--color-text-muted);font-size:var(--font-size-xs);margin:0}.reports-subtitle{color:var(--color-text-light);margin:0;font-size:var(--font-size-base)}.reports-menu-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:var(--space-sm);margin-bottom:var(--space-lg)}.report-btn{display:flex;flex-direction:column;align-items:flex-start;gap:var(--space-xs);width:100%;padding:var(--space-md);border-radius:var(--radius-md);border:1px solid var(--color-border-light);background:var(--color-surface);color:var(--color-text);font-weight:var(--font-weight-semibold);transition:transform var(--transition-fast),box-shadow var(--transition-fast),border-color var(--transition-fast);min-height:var(--touch-target-min);text-align:left;cursor:pointer}.report-btn:hover,.report-btn:focus-visible{border-color:var(--color-primary);box-shadow:var(--shadow-sm);transform:translateY(-1px);outline:none}.report-btn--accent{background:linear-gradient(135deg,var(--color-primary),var(--color-primary-dark));color:var(--color-selected-text);border-color:transparent}.report-surface{background:var(--color-surface);border:1px solid var(--color-border-light);border-radius:var(--radius-lg);padding:var(--space-md);box-shadow:var(--shadow-base)}.report-view{display:grid;gap:var(--space-md)}.report-actions{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:var(--space-sm)}.report-card{background:var(--color-background);border-radius:var(--radius-lg);border:1px solid var(--color-border-light);padding:var(--space-md);box-shadow:var(--shadow-sm);display:grid;gap:var(--space-md)}.report-card__header{display:flex;justify-content:space-between;gap:var(--space-sm);align-items:center;flex-wrap:wrap}.report-card__grid{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-md)}.progress-summary{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:var(--space-sm)}.summary-tile{background:var(--color-surface);border:1px solid var(--color-border-light);border-radius:var(--radius-md);padding:var(--space-sm);box-shadow:var(--shadow-sm)}.summary-label{margin:0;color:var(--color-text-muted);font-size:var(--font-size-sm)}.summary-value{margin:0;font-size:var(--font-size-xl);font-weight:var(--font-weight-bold);color:var(--color-primary-dark)}.points-chart{width:100%;height:auto;max-height:240px}.chart-placeholder{background:var(--color-secondary);color:var(--color-text-muted);padding:var(--space-md);border-radius:var(--radius-md);text-align:center}.timeline{position:relative;padding-left:var(--space-lg);border-left:2px solid var(--color-border-light);display:grid;gap:var(--space-sm)}.timeline-item{position:relative;padding-left:var(--space-sm)}.timeline-dot{position:absolute;left:calc(-1 * var(--space-lg));top:.5rem;width:12px;height:12px;border-radius:var(--radius-full);background:var(--color-primary);box-shadow:0 0 0 4px #4c65ae1f}.timeline-title{margin:0;font-weight:var(--font-weight-semibold)}.timeline-meta,.timeline-date{margin:0;color:var(--color-text-muted);font-size:var(--font-size-sm)}.timeline-item--honor .timeline-dot{background:var(--color-success)}.timeline-item--badge .timeline-dot{background:var(--color-warning)}.timeline-item--attendance .timeline-dot{background:var(--color-primary)}.chip{display:inline-flex;align-items:center;gap:var(--space-xs);padding:.4rem .75rem;background:var(--color-secondary);color:var(--color-text);border-radius:var(--radius-full);font-size:var(--font-size-sm)}.chip--primary{background:var(--color-primary);color:var(--color-selected-text)}.chip-row{display:flex;flex-wrap:wrap;gap:var(--space-xs)}.offline-notice{background:var(--color-warning-light);color:var(--color-text);padding:var(--space-sm);border-radius:var(--radius-md);font-size:var(--font-size-sm);margin-bottom:var(--space-sm)}.form-field{display:grid;gap:var(--space-xs)}.report-category{margin-bottom:var(--space-2xl)}.report-category-title{font-size:var(--font-size-lg);font-weight:var(--font-weight-semibold);color:var(--color-text);margin:0 0 var(--space-md) 0;padding-bottom:var(--space-xs);border-bottom:2px solid var(--color-border-light)}.district-management{display:flex;flex-direction:column;gap:var(--space-md);padding-block-end:calc(var(--space-xl) + var(--safe-area-bottom))}.dm-header h1{margin:0}.dm-subtitle{color:var(--color-text-muted);margin:var(--space-xs) 0 0 0;font-size:var(--font-size-sm)}.dm-controls{display:flex;flex-direction:column;gap:var(--space-sm);background:var(--color-surface);padding:var(--space-md);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm)}.dm-org-context{margin:var(--space-sm) 0 var(--space-md);padding:var(--space-md);background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg)}.dm-org-context select{width:100%;padding:var(--space-sm);border-radius:var(--radius-md);border:1px solid var(--color-border)}.dm-search input{width:100%;padding:var(--space-md);border-radius:var(--radius-md);border:1px solid var(--color-border);font-size:var(--font-size-base)}.dm-filters{display:flex;flex-wrap:wrap;gap:var(--space-sm)}.dm-offline-banner{display:inline-flex;align-items:center;gap:var(--space-sm);padding:var(--space-sm) var(--space-md);background:var(--color-warning-light);color:var(--color-text);border-radius:var(--radius-md);box-shadow:var(--shadow-sm)}.dm-queued{display:flex;align-items:center;gap:var(--space-sm);flex-wrap:wrap;padding:var(--space-sm) 0}.dm-warning{margin:var(--space-sm) 0;padding:var(--space-sm);background:var(--color-warning-light);border-radius:var(--radius-md)}.dm-user-list{display:grid;grid-template-columns:1fr;gap:var(--space-sm)}.dm-user-card{display:flex;flex-direction:column;gap:var(--space-sm);padding:var(--space-md);text-align:left;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm)}.dm-user-card:focus-visible{outline:3px solid var(--color-primary);outline-offset:2px}.dm-card-header{display:flex;justify-content:space-between;gap:var(--space-sm);align-items:flex-start}.dm-user-name{margin:0;font-weight:var(--font-weight-semibold);color:var(--color-text)}.dm-user-email{margin:0;color:var(--color-text-muted);font-size:var(--font-size-sm)}.dm-role-stack{display:flex;flex-wrap:wrap;gap:var(--space-xs)}.dm-role-chip{background:var(--color-secondary)}.dm-action-bar{position:sticky;inset-block-end:0;background:var(--color-surface);padding:var(--space-md);margin-inline:-var(--space-md);box-shadow:0 -2px 12px #00000014;display:flex;justify-content:space-between;align-items:center;gap:var(--space-sm);z-index:var(--z-sticky)}.dm-action-bar__left{display:flex;gap:var(--space-sm);align-items:center}.dm-action-bar__right{display:flex;gap:var(--space-sm)}.dm-sync{font-size:var(--font-size-sm);color:var(--color-text-muted)}.dm-modal .dm-modal-header{display:flex;justify-content:space-between;gap:var(--space-md);align-items:flex-start}.dm-modal .dm-modal-body{display:flex;flex-direction:column;gap:var(--space-md);margin-top:var(--space-md)}.dm-modal .dm-modal-actions{display:flex;gap:var(--space-sm);justify-content:flex-end;padding-top:var(--space-md)}.dm-modal .dm-section-title{margin:0 0 var(--space-xs) 0;font-weight:var(--font-weight-semibold)}.dm-modal .dm-bundle-list{display:grid;gap:var(--space-sm)}.dm-modal .dm-bundle{display:grid;gap:var(--space-xs);padding:var(--space-md);border:1px solid var(--color-border);border-radius:var(--radius-md);background:var(--color-surface)}.dm-bundle-header{display:flex;gap:var(--space-sm);align-items:flex-start}.dm-bundle-title{margin:0;font-weight:var(--font-weight-semibold);color:var(--color-text)}.dm-bundle-meta{margin:0;color:var(--color-text-muted);font-size:var(--font-size-sm)}.dm-bundle-description{margin:0;color:var(--color-text);font-size:var(--font-size-sm)}.dm-modal textarea{width:100%;border:1px solid var(--color-border);border-radius:var(--radius-md);padding:var(--space-sm);font-size:var(--font-size-base)}.dm-helper{margin:var(--space-xs) 0 0 0;color:var(--color-text-muted);font-size:var(--font-size-sm)}.dm-optional{color:var(--color-text-muted);font-size:var(--font-size-sm);margin-inline-start:var(--space-xs)}.dm-high-risk{border:1px solid var(--color-warning);background:#fff9ed;border-radius:var(--radius-md);padding:var(--space-md)}.dm-mfa-actions{display:flex;gap:var(--space-sm);flex-wrap:wrap;align-items:center}.dm-checkbox{display:flex;gap:var(--space-xs);align-items:center;margin-top:var(--space-sm)}@media(min-width:768px){.dm-controls{flex-direction:row;align-items:center;justify-content:space-between}.dm-user-list{grid-template-columns:repeat(auto-fit,minmax(260px,1fr))}.dm-action-bar{position:sticky;inset-block-end:var(--space-sm);border-radius:var(--radius-lg);margin-inline:0}.dm-modal .dm-modal-actions{justify-content:space-between}}.report-btn-icon{font-size:1.5rem;line-height:1}.report-btn-label{font-weight:var(--font-weight-semibold);color:var(--color-text);font-size:var(--font-size-base);display:block}.report-btn-desc{font-size:var(--font-size-sm);color:var(--color-text-muted);line-height:var(--line-height-normal);display:block}.report-btn--featured{background:linear-gradient(135deg,var(--color-primary),var(--color-primary-dark));border-color:transparent}.report-btn--featured .report-btn-label,.report-btn--featured .report-btn-desc{color:var(--color-selected-text)}.report-category--advanced{background:var(--color-secondary);border-radius:var(--radius-lg);padding:var(--space-md);margin-top:var(--space-xl)}.report-advanced-toggle{cursor:pointer}.report-advanced-toggle[open] .report-advanced-icon{transform:rotate(180deg)}.report-advanced-summary{display:flex;justify-content:space-between;align-items:center;cursor:pointer;list-style:none;user-select:none}.report-advanced-summary::-webkit-details-marker{display:none}.report-advanced-icon{font-size:var(--font-size-sm);transition:transform var(--transition-base);color:var(--color-text-muted)}.report-advanced-content{margin-top:var(--space-md);padding-top:var(--space-md);border-top:1px solid var(--color-border-light)}.report-advanced-desc{color:var(--color-text-light);font-size:var(--font-size-sm);margin-bottom:var(--space-md)}.form-help{color:var(--color-text-muted);font-size:var(--font-size-xs);display:block;margin-top:var(--space-xs)}.report-modal{position:fixed;inset:0;z-index:var(--z-modal);display:flex;align-items:center;justify-content:center}.report-modal-overlay{position:fixed;inset:0;background:#00000080;backdrop-filter:blur(4px);animation:fadeIn var(--transition-base)}.report-modal-container{position:relative;width:100%;height:100%;max-width:100vw;max-height:100vh;background:var(--color-surface);display:flex;flex-direction:column;animation:slideUp var(--transition-base)}.report-modal-header{display:flex;justify-content:space-between;align-items:center;gap:var(--space-md);padding:var(--space-md) var(--space-lg);background:var(--color-surface);border-bottom:2px solid var(--color-border-light);flex-shrink:0;box-shadow:var(--shadow-sm);z-index:var(--z-base)}.report-modal-title{font-size:var(--font-size-xl);font-weight:var(--font-weight-semibold);color:var(--color-text);margin:0;flex:1}.report-modal-actions{display:flex;gap:var(--space-sm);align-items:center}.report-modal-content{flex:1;overflow-y:auto;overflow-x:hidden;padding:var(--space-lg);background:var(--color-background)}@media print{.report-modal-header{border-bottom:1px solid #000;padding:var(--space-sm)}.report-modal-actions,.report-modal-overlay{display:none}.report-modal-container{box-shadow:none}}.button--secondary{background:var(--color-secondary);color:var(--color-text);border:1px solid var(--color-border)}.button--secondary:hover,.button--secondary:focus-visible{background:var(--color-border-light);border-color:var(--color-primary)}.button--ghost{background:transparent;color:var(--color-text-muted);border:none;padding:var(--space-sm);min-width:auto;font-size:var(--font-size-xl);line-height:1}.button--ghost:hover,.button--ghost:focus-visible{background:var(--color-secondary);color:var(--color-text)}.button-icon{display:inline-block;margin-right:var(--space-xs);line-height:1}.button--ghost .button-icon{margin-right:0}@media(max-width:960px){.badge-table__header,.badge-table__row,.reports-menu-grid,.report-card__grid{grid-template-columns:1fr}.badge-table__cell{border-top:1px solid var(--color-border-light);padding-top:var(--space-xs)}.modal{max-width:95vw;max-height:90vh}.form-row{grid-template-columns:1fr}.modal__header h2{font-size:var(--font-size-lg)}.report-modal-header{padding:var(--space-sm) var(--space-md)}.report-modal-title{font-size:var(--font-size-lg)}.report-modal-content{padding:var(--space-md)}.report-modal-actions{gap:var(--space-xs)}}@media(max-width:480px){.report-modal-actions .button:not(.button--ghost){padding:var(--space-xs) var(--space-sm);font-size:var(--font-size-sm)}.report-modal-actions .button .button-icon{margin-right:var(--space-xs)}}.fundraisers-header{display:flex;align-items:center;gap:1rem;margin-bottom:1.5rem}.fundraisers-container{max-width:100%;margin:0 auto}.fundraisers-list{display:grid;grid-template-columns:1fr;gap:1rem;margin-bottom:2rem}@media(min-width:768px){.fundraisers-list{grid-template-columns:repeat(2,1fr)}}@media(min-width:1024px){.fundraisers-list{grid-template-columns:repeat(3,1fr)}}.fundraiser-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:8px;padding:1.25rem;box-shadow:0 2px 4px #0000001a;transition:box-shadow .2s ease}.fundraiser-card:hover{box-shadow:0 4px 8px #00000026}.fundraiser-card.archived{opacity:.7;background:var(--color-secondary)}.fundraiser-card-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:1rem;gap:.5rem}.fundraiser-card-header h2{margin:0;font-size:1.25rem;color:var(--color-text);flex:1}.status-badge{padding:.25rem .75rem;border-radius:12px;font-size:.875rem;font-weight:600;white-space:nowrap}.status-badge.active{background-color:var(--color-success-light);color:#fff}.status-badge.inactive{background-color:var(--color-text-muted);color:#fff}.status-badge.archived,.status-badge.status-pending{background-color:var(--color-warning);color:var(--color-text)}.status-badge.status-signed{background-color:var(--color-success);color:#fff}.date-quick-links{display:flex;flex-wrap:wrap;gap:.75rem;margin-top:.5rem}.date-quick-link{padding:.625rem 1rem;border-radius:var(--radius-md);font-size:.9375rem;font-weight:500;border:2px solid var(--color-border);background-color:var(--color-surface);color:var(--color-text);cursor:pointer;transition:all var(--transition-base);display:inline-flex;align-items:center;gap:.5rem;text-decoration:none;touch-action:manipulation;user-select:none;-webkit-user-select:none;-webkit-tap-highlight-color:transparent}.date-quick-link:hover{border-color:var(--color-primary);background-color:var(--color-secondary);transform:translateY(-1px);box-shadow:var(--shadow-sm)}.date-quick-link:active{transform:translateY(0)}.date-quick-link.has-pending{border-color:var(--color-warning);background-color:#fff9ed;color:var(--color-text);font-weight:600}.date-quick-link.has-pending:hover{border-color:var(--color-warning);background-color:#fff4d6}.date-quick-link.complete{border-color:var(--color-success);background-color:#f0fdf7;color:var(--color-success)}.date-quick-link.complete:hover{border-color:var(--color-success);background-color:#dff8ed}@media(max-width:768px){.date-quick-links{flex-direction:column}.date-quick-link{width:100%;justify-content:center}}.fundraiser-card-body{margin-bottom:1rem}.fundraiser-info p{margin:.5rem 0;color:var(--color-text-light);font-size:.9375rem}.fundraiser-card-footer{display:flex;flex-wrap:wrap;gap:.5rem;padding-top:1rem;border-top:1px solid var(--color-border-light)}.archived-section{margin-top:3rem;padding-top:2rem;border-top:2px solid var(--color-border)}.toggle-btn{width:100%;padding:.75rem;margin-bottom:1rem;background:var(--color-secondary);border:1px solid var(--color-border);border-radius:4px;cursor:pointer;font-size:1rem;color:var(--color-text);transition:background-color .2s ease}.toggle-btn:hover{background:var(--color-border-light)}.toggle-btn:focus{outline:2px solid var(--color-primary);outline-offset:2px}.calendars-header{margin-bottom:1.5rem}.header-nav{display:flex;align-items:center;gap:1rem;margin-bottom:1rem}.back-button{color:var(--color-primary);text-decoration:none;font-weight:500;transition:color .2s ease}.back-button:hover{color:var(--color-primary-dark);text-decoration:underline}.fundraiser-header-info h1{margin:.5rem 0;font-size:1.75rem;color:var(--color-text)}.fundraiser-dates{color:var(--color-text-muted);font-size:1rem;margin:0}.calendars-controls{margin-bottom:1.5rem}.sort-toggle{display:flex;gap:.5rem;flex-wrap:wrap;justify-content:center}.sort-btn{padding:.5rem 1rem;background:var(--color-surface);border:2px solid var(--color-border);border-radius:4px;cursor:pointer;font-size:.9375rem;color:var(--color-text);transition:all .2s ease;display:flex;align-items:center;gap:.5rem}.sort-btn:hover{background:var(--color-secondary);border-color:var(--color-primary)}.sort-btn:focus{outline:2px solid var(--color-primary);outline-offset:2px}.sort-btn.active{background:var(--color-primary);color:#fff;border-color:var(--color-primary)}.calendars-table-container{overflow-x:auto;margin-bottom:1.5rem}.calendars-table{width:100%;border-collapse:collapse;background:var(--color-surface);box-shadow:0 2px 4px #0000001a}.calendars-table tbody tr:hover{background:var(--color-secondary)}.calendars-table input[type=number]{width:100%;max-width:none;padding:.5rem;border:1px solid var(--color-border);border-radius:4px;font-size:.9375rem}.calendars-table input[type=number]:focus{outline:2px solid var(--color-primary);outline-offset:1px;border-color:var(--color-primary)}.calendars-table input[type=checkbox]{width:1.25rem;height:1.25rem;cursor:pointer}.calendars-table input[type=checkbox]:focus{outline:2px solid var(--color-primary);outline-offset:2px}.calendars-summary{background:var(--color-secondary);padding:1.25rem;border-radius:8px;margin-bottom:1.5rem}.calendars-summary p{margin:.5rem 0;color:var(--color-text-light)}.calendars-summary strong{color:var(--color-text)}.form-group label{display:block;margin-bottom:.5rem;font-weight:500;color:var(--color-text)}.form-group input[type=text],.form-group input[type=date],.form-group input[type=number]{width:100%;padding:.625rem;border:1px solid var(--color-border);border-radius:4px;font-size:1rem;transition:border-color .2s ease}.form-group input:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px #4c65ae1a}.primary-btn,.btn-secondary,.btn-danger,.btn-link{padding:.625rem 1.25rem;border-radius:4px;font-size:.9375rem;font-weight:500;cursor:pointer;transition:all .2s ease;text-decoration:none;display:inline-block;border:none}.primary-btn{background:var(--color-primary);color:#fff}.primary-btn:hover{background:var(--color-primary-dark)}.primary-btn:focus{outline:2px solid var(--color-primary);outline-offset:2px}.btn-secondary{background:var(--color-secondary);color:var(--color-text);border:1px solid var(--color-border)}.btn-secondary:hover{background:var(--color-border-light)}.btn-danger{background:var(--color-error);color:#fff}.btn-danger:hover{background:var(--color-error-light)}.btn-link{background:var(--color-primary);color:#fff;text-align:center}.btn-link:hover{background:var(--color-primary-dark);text-decoration:none}.modal-cancel{background:var(--color-secondary);color:var(--color-text);border:1px solid var(--color-border)}@media(max-width:768px){.fundraiser-card-footer{flex-direction:column}.fundraiser-card-footer .btn-secondary,.fundraiser-card-footer .btn-danger,.fundraiser-card-footer .btn-link{width:100%;text-align:center}.calendars-table{font-size:.875rem}}@media print{.fundraisers-header,.header-nav,.calendars-controls,.fundraiser-card-footer,.archived-section,.modal,#print-view-btn{display:none!important}.calendars-table{box-shadow:none}}.finance-page{display:flex;flex-direction:column;gap:1rem;padding:1rem}.finance-header{display:flex;align-items:center;gap:.75rem}.finance-kicker{margin:0;text-transform:uppercase;letter-spacing:.08em;color:#6b7280;font-size:.8rem}.finance-subtitle{margin:.25rem 0 0;color:#4b5563}.finance-tabs{display:none}@media(min-width:768px){.finance-tabs{display:flex;gap:.5rem;overflow-x:auto;padding-bottom:.25rem}}.finance-tab{flex:1;min-width:160px;border:1px solid #e5e7eb;background:#fff;padding:.75rem;border-radius:10px;font-weight:700;color:#111827}.finance-tab.active{background:#0d6efd;border-color:#0d6efd;color:#fff}.finance-content{display:flex;flex-direction:column;gap:1rem}.finance-grid{display:grid;grid-template-columns:1fr;gap:1rem}.finance-card{background:#fff;border:1px solid #e5e7eb;border-radius:12px;padding:1rem;box-shadow:0 4px 12px #00000008}.finance-card__header{display:flex;align-items:center;justify-content:space-between;gap:.5rem}.finance-card--highlight{border-left:4px solid #0d6efd}.finance-stats,.finance-amounts{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:.75rem}.finance-stat__label{margin:0;color:#6b7280;font-size:.9rem}.finance-stat__value{margin:.15rem 0;font-size:1.2rem;font-weight:700}.finance-stat__value--alert{color:#b91c1c}.finance-inline-form{display:grid;gap:.5rem;margin:.5rem 0}.finance-inline-form select,.finance-inline-form textarea{width:100%}.finance-actions{display:flex;flex-wrap:wrap;gap:.5rem;margin-top:.5rem}.finance-helper{color:#6b7280}.finance-pill{background:#e5f1ff;color:#0d6efd;padding:.35rem .65rem;border-radius:999px;font-weight:700;font-size:.85rem}.finance-meta{color:#6b7280;margin:.15rem 0;font-size:.95rem}.finance-list{display:flex;flex-direction:column;gap:.5rem}.finance-list__row{display:flex;align-items:center;justify-content:space-between;gap:.75rem;padding:.75rem;border:1px solid #e5e7eb;border-radius:10px;background:#f9fafb}.finance-row-values{display:flex;gap:.75rem;align-items:center;font-weight:600}.finance-form label{font-weight:600;display:block;margin-top:.5rem}.finance-form input,.finance-form select,.finance-form textarea{width:100%;margin-top:.25rem}.finance-form button{margin-top:.75rem}.financial-report .finance-card{padding:.75rem}@media(min-width:768px){.finance-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}.budgets-page.page-container{padding:var(--space-lg);max-width:1400px;margin:0 auto}.budgets-page .page-header{display:flex;align-items:flex-start;margin-bottom:var(--space-xl);gap:var(--space-md)}.budgets-page .page-header .home-icon{flex-shrink:0;margin-top:.25rem}.budgets-page .page-header-content{flex:1;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:var(--space-md)}.budgets-page .page-header h1{margin:0;font-size:var(--font-size-2xl);color:var(--color-text)}.fiscal-year-display{background:var(--color-surface);padding:var(--space-sm) var(--space-md);border-radius:var(--radius-md);border:1px solid var(--color-border);font-size:var(--font-size-sm);color:var(--color-text-light)}.fiscal-year-display strong{color:var(--color-primary);font-weight:var(--font-weight-semibold)}.summary-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:var(--space-lg);margin-bottom:var(--space-xl)}.summary-card{background:var(--color-surface);padding:var(--space-lg);border-radius:var(--radius-lg);box-shadow:var(--shadow-md);display:flex;align-items:center;gap:var(--space-md);transition:transform var(--transition-base),box-shadow var(--transition-base)}.summary-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-lg)}.summary-card .card-icon{font-size:2.5rem;flex-shrink:0}.summary-card .card-content{flex:1}.summary-card .card-label{font-size:var(--font-size-sm);color:var(--color-text-muted);margin-bottom:var(--space-xs);text-transform:uppercase;letter-spacing:.05em;font-weight:var(--font-weight-medium)}.summary-card .card-value{font-size:var(--font-size-xl);font-weight:var(--font-weight-bold);color:var(--color-text)}.summary-card.revenue-card{border-left:4px solid var(--color-success)}.summary-card.expense-card{border-left:4px solid var(--color-warning)}.summary-card.net-card.positive{border-left:4px solid var(--color-success)}.summary-card.net-card.negative{border-left:4px solid var(--color-error)}.budgets-page .tab-navigation{display:flex;gap:var(--space-xs);margin-bottom:var(--space-lg);border-bottom:2px solid var(--color-border);flex-wrap:wrap;scrollbar-width:thin}.budgets-page .tab-btn{padding:var(--space-md) var(--space-lg);border:none;background:transparent;color:var(--color-text-light);font-size:var(--font-size-base);font-weight:var(--font-weight-medium);cursor:pointer;white-space:nowrap;border-bottom:3px solid transparent;margin-bottom:-2px;transition:all var(--transition-base)}.budgets-page .tab-btn:hover{color:var(--color-primary);background:var(--color-secondary)}.budgets-page .tab-btn.active{color:var(--color-primary);border-bottom-color:var(--color-primary);font-weight:var(--font-weight-semibold)}.budgets-page .tab-content{min-height:400px}.overview-content h2{font-size:var(--font-size-xl);color:var(--color-text);margin-bottom:var(--space-lg)}.overview-content .budget-table{width:100%;border-collapse:collapse;background:var(--color-surface);border-radius:var(--radius-md);overflow:hidden;box-shadow:var(--shadow-base)}.overview-content .budget-table th{background:var(--color-primary);color:#fff;padding:var(--space-md);text-align:left;font-weight:var(--font-weight-semibold);font-size:var(--font-size-sm)}.overview-content .budget-table th.text-right{text-align:right}.overview-content .budget-table td{padding:var(--space-md);border-bottom:1px solid var(--color-border-light)}.overview-content .budget-table tr:last-child td{border-bottom:none}.overview-content .budget-table tr:hover{background:var(--color-secondary)}.overview-content .amount{font-weight:var(--font-weight-medium);font-family:Courier New,monospace}.overview-content .amount.revenue{color:var(--color-success)}.overview-content .amount.expense{color:var(--color-error)}.overview-content .amount.positive{color:var(--color-success)}.overview-content .amount.negative{color:var(--color-error)}.categories-content .section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--space-lg);flex-wrap:wrap;gap:var(--space-md)}.categories-content h2{font-size:var(--font-size-xl);color:var(--color-text);margin:0}.categories-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:var(--space-lg)}.category-card{background:var(--color-surface);padding:var(--space-lg);border-radius:var(--radius-lg);box-shadow:var(--shadow-base);border-left:4px solid var(--color-primary);transition:transform var(--transition-base),box-shadow var(--transition-base)}.category-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-md)}.category-card .category-header{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:var(--space-md);gap:var(--space-sm)}.category-card h3{margin:0;font-size:var(--font-size-lg);color:var(--color-text);flex:1}.category-card .item-count{font-size:var(--font-size-sm);color:var(--color-text-muted);white-space:nowrap}.category-card .category-description{color:var(--color-text-light);font-size:var(--font-size-sm);margin-bottom:var(--space-md);line-height:var(--line-height-normal)}.category-card .category-actions{display:flex;gap:var(--space-sm);margin-top:var(--space-md);padding-top:var(--space-md);border-top:1px solid var(--color-border-light)}.expenses-content .section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--space-lg);flex-wrap:wrap;gap:var(--space-md)}.expenses-content h2{font-size:var(--font-size-xl);color:var(--color-text);margin:0}.expenses-table{width:100%;border-collapse:collapse;background:var(--color-surface);border-radius:var(--radius-md);overflow:hidden;box-shadow:var(--shadow-base)}.expenses-table th{background:var(--color-primary);color:#fff;padding:var(--space-md);text-align:left;font-weight:var(--font-weight-semibold);font-size:var(--font-size-sm)}.expenses-table th.text-right{text-align:right}.expenses-table td{padding:var(--space-md);border-bottom:1px solid var(--color-border-light);font-size:var(--font-size-sm)}.expenses-table tr:last-child td{border-bottom:none}.expenses-table tr:hover{background:var(--color-secondary)}.expenses-table .text-center{text-align:center;color:var(--color-text-muted);font-style:italic}.expenses-table .amount.expense{color:var(--color-error);font-weight:var(--font-weight-medium);font-family:Courier New,monospace}.reports-content{text-align:center;padding:var(--space-2xl)}.reports-content h2{font-size:var(--font-size-xl);color:var(--color-text);margin-bottom:var(--space-md)}.reports-content p{color:var(--color-text-muted);font-size:var(--font-size-base)}.no-data{text-align:center;padding:var(--space-2xl);color:var(--color-text-muted);font-size:var(--font-size-base);background:var(--color-secondary);border-radius:var(--radius-md);border:2px dashed var(--color-border)}@media(max-width:768px){.budgets-page.page-container{padding:var(--space-md)}.summary-cards{grid-template-columns:1fr}.budgets-page .page-header{flex-direction:column;align-items:flex-start}.categories-grid{grid-template-columns:1fr}.expenses-table{font-size:var(--font-size-xs)}.expenses-table th,.expenses-table td{padding:var(--space-sm)}.expenses-content{overflow-x:auto}}*:focus-visible{outline:2px solid var(--color-primary);outline-offset:2px}@media(prefers-contrast:high){.fundraiser-card,.calendars-table,.modal-content,.sort-btn,.primary-btn,.btn-secondary{border-width:2px}}.budget-widget-card{margin-bottom:var(--space-lg)}.budget-widget-summary{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:var(--space-md);margin-bottom:var(--space-md)}.budget-stat{display:flex;flex-direction:column;gap:var(--space-xs);padding:var(--space-md);background-color:var(--color-background);border-radius:var(--radius-md);border-left:3px solid var(--color-border)}.budget-stat-label{font-size:var(--font-size-sm);color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.05em;font-weight:var(--font-weight-medium)}.budget-stat-value{font-size:var(--font-size-xl);font-weight:var(--font-weight-bold);color:var(--color-text)}.budget-stat-value.revenue{color:var(--color-success)}.budget-stat-value.expense{color:var(--color-warning)}.budget-stat-value.positive{color:var(--color-success)}.budget-stat-value.negative{color:var(--color-error)}.budget-widget-fiscal-year{font-size:var(--font-size-sm);margin:0}@media(max-width:768px){.budget-widget-summary{grid-template-columns:1fr}}.reports-content{padding:var(--space-md)}.report-section{margin-bottom:var(--space-xl);padding:var(--space-lg);background-color:var(--color-surface);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm)}.report-section h2{margin-top:0;margin-bottom:var(--space-lg);color:var(--color-text)}.report-section h3{margin-top:var(--space-lg);margin-bottom:var(--space-md);font-size:var(--font-size-md);color:var(--color-text-muted)}.profit-loss-statement{page-break-inside:avoid}.statement-period{margin-bottom:var(--space-lg);font-size:var(--font-size-sm)}.statement-section{margin-bottom:var(--space-xl)}.statement-section-title{font-size:var(--font-size-lg);margin-bottom:var(--space-md);padding-bottom:var(--space-sm);border-bottom:2px solid var(--color-border)}.statement-table{width:100%;margin-bottom:var(--space-md)}.statement-total{border-top:2px solid var(--color-border);font-weight:var(--font-weight-bold)}.statement-net{font-size:var(--font-size-lg);border-top:3px double var(--color-border)}.statement-net.positive td{color:var(--color-success)}.statement-net.negative td{color:var(--color-error)}.net-section{margin-top:var(--space-xl)}.trends-section{margin-bottom:var(--space-xl)}.trend-bars{display:flex;flex-direction:column;gap:var(--space-md)}.trend-item{display:grid;grid-template-columns:1fr auto;gap:var(--space-sm);align-items:center}.trend-label{display:flex;justify-content:space-between;align-items:center;gap:var(--space-sm);min-width:200px}.trend-amount{font-weight:var(--font-weight-medium);color:var(--color-text-muted)}.trend-bar-container{flex:1;height:24px;background-color:var(--color-background);border-radius:var(--radius-md);overflow:hidden;min-width:100px}.trend-bar{height:100%;transition:width var(--transition-base);border-radius:var(--radius-md)}.trend-bar.revenue{background:linear-gradient(90deg,var(--color-success),var(--color-success-light))}.trend-bar.expense{background:linear-gradient(90deg,var(--color-warning),var(--color-warning-light))}.trend-percentage{min-width:60px;text-align:right;font-weight:var(--font-weight-medium);color:var(--color-text-muted)}.breakdown-section{margin-bottom:var(--space-xl)}.breakdown-section:last-child{margin-bottom:0}.breakdown-table{width:100%}.breakdown-total{border-top:2px solid var(--color-border);font-weight:var(--font-weight-bold)}@media(max-width:768px){.trend-item{grid-template-columns:1fr}.trend-label{min-width:auto}.trend-percentage{text-align:left}}@media print{.report-section{page-break-inside:avoid;box-shadow:none}.statement-section{page-break-inside:avoid}}.revenue-filters{display:flex;flex-wrap:wrap;gap:var(--space-md);align-items:flex-end;margin-bottom:var(--space-lg);padding:var(--space-md);background-color:var(--color-surface);border-radius:var(--radius-md)}.filter-group{display:flex;flex-direction:column;gap:var(--space-xs);min-width:200px}.filter-group label{font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--color-text-muted)}.filter-select{padding:var(--space-sm) var(--space-md);border:1px solid var(--color-border);border-radius:var(--radius-md);background-color:var(--color-background);font-size:var(--font-size-base);color:var(--color-text);min-height:var(--touch-target-min)}.filter-select:focus{outline:2px solid var(--color-primary);outline-offset:2px}.breakdown-summary{display:flex;gap:var(--space-lg);margin-bottom:var(--space-lg);padding:var(--space-md);background-color:var(--color-surface);border-radius:var(--radius-md);border-left:3px solid var(--color-primary)}.summary-stat{display:flex;flex-direction:column;gap:var(--space-xs)}.stat-label{font-size:var(--font-size-sm);color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.05em;font-weight:var(--font-weight-medium)}.stat-value{font-size:var(--font-size-lg);font-weight:var(--font-weight-bold);color:var(--color-text)}.stat-value.revenue{color:var(--color-success)}@media(max-width:768px){.revenue-filters{flex-direction:column}.filter-group{width:100%;min-width:auto}.breakdown-summary{flex-direction:column}}.planning-content{padding:var(--space-md)}.planning-info{margin-bottom:var(--space-lg);padding:var(--space-md);background-color:var(--color-surface);border-radius:var(--radius-md)}.plans-table{width:100%;margin-bottom:var(--space-xl)}.notes-cell{max-width:200px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.budget-vs-actual{margin-top:var(--space-xl);padding:var(--space-lg);background-color:var(--color-surface);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm)}.budget-vs-actual h3{margin-top:0;margin-bottom:var(--space-lg)}.comparison-table{width:100%}.comparison-table .positive{color:var(--color-success);font-weight:var(--font-weight-medium)}.comparison-table .negative{color:var(--color-error);font-weight:var(--font-weight-medium)}.form-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:var(--space-md);margin-bottom:var(--space-md)}@media(max-width:768px){.notes-cell{max-width:100px}.form-row{grid-template-columns:1fr}}.filters-section{background:var(--color-surface);padding:var(--space-lg);border-radius:var(--radius-lg);margin-bottom:var(--space-xl);box-shadow:var(--shadow-sm)}.filters-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:var(--space-md);align-items:end}.filter-group{display:flex;flex-direction:column;gap:var(--space-xs)}.filter-group label{font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--color-text-secondary)}.filter-group input,.filter-group select{padding:var(--space-sm) var(--space-md);border:1px solid var(--color-border);border-radius:var(--radius-md);font-size:var(--font-size-base);background:var(--color-background);min-height:44px}.filter-actions{display:flex;gap:var(--space-sm);flex-wrap:wrap}.action-buttons{display:flex;gap:var(--space-md);margin-bottom:var(--space-xl);flex-wrap:wrap}.action-buttons .btn{min-height:44px;padding:var(--space-sm) var(--space-lg)}.revenue-list,.expense-list{background:var(--color-surface);border-radius:var(--radius-lg);padding:var(--space-md);box-shadow:var(--shadow-sm);overflow-x:auto}.revenue-table,.expense-table{min-width:800px}.tax-calculator-section{background:var(--color-surface-secondary);padding:var(--space-lg);border-radius:var(--radius-md);margin:var(--space-lg) 0}.tax-calculator-section h4{margin-top:0;margin-bottom:var(--space-md)}.tax-breakdown{background:var(--color-background);padding:var(--space-md);border-radius:var(--radius-md);margin-top:var(--space-md)}.tax-breakdown p{margin:var(--space-sm) 0;display:flex;justify-content:space-between}.bulk-expense-row{background:var(--color-surface);padding:var(--space-md);border-radius:var(--radius-md);margin-bottom:var(--space-md);border-left:3px solid var(--color-primary)}.form-group-sm{min-width:120px}.remove-bulk-row-btn{align-self:flex-end;min-width:44px;min-height:44px}.monthly-view{display:flex;flex-direction:column;gap:var(--space-xl)}.month-section{background:var(--color-surface);padding:var(--space-lg);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm)}.month-section h3{margin-top:0;margin-bottom:var(--space-md);color:var(--color-primary)}.summary-view{background:var(--color-surface);padding:var(--space-lg);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm)}.date-range-selector{background:var(--color-surface);padding:var(--space-lg);border-radius:var(--radius-lg);margin-bottom:var(--space-xl);box-shadow:var(--shadow-sm)}.date-range-inputs{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:var(--space-md);align-items:end}.source-group{background:var(--color-surface);padding:var(--space-lg);border-radius:var(--radius-lg);margin-bottom:var(--space-xl);box-shadow:var(--shadow-sm)}.source-group h3{margin-top:0;margin-bottom:var(--space-sm);color:var(--color-primary)}.source-summary{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--space-lg);padding-bottom:var(--space-md);border-bottom:2px solid var(--color-border)}.source-total{font-size:var(--font-size-xl);font-weight:var(--font-weight-bold);color:var(--color-success)}.source-count{font-size:var(--font-size-sm);color:var(--color-text-secondary)}.horizontal-bar-chart{display:flex;flex-direction:column;gap:var(--space-md);margin:var(--space-xl) 0}.chart-bar-item{display:grid;grid-template-columns:1fr 2fr auto;gap:var(--space-md);align-items:center}.chart-label{display:flex;flex-direction:column;gap:var(--space-xs)}.chart-label span:first-child{font-weight:var(--font-weight-medium);font-size:var(--font-size-sm)}.chart-value{font-size:var(--font-size-sm);color:var(--color-text-secondary)}.chart-bar-container{background:var(--color-surface-secondary);border-radius:var(--radius-full);height:24px;overflow:hidden}.chart-bar{height:100%;border-radius:var(--radius-full);transition:width var(--transition-base)}.chart-bar.revenue{background:linear-gradient(90deg,var(--color-success),var(--color-primary))}.chart-bar.expense{background:linear-gradient(90deg,var(--color-warning),var(--color-error))}.chart-percentage{font-weight:var(--font-weight-semibold);font-size:var(--font-size-sm);min-width:60px;text-align:right}.comparison-summary{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:var(--space-lg);margin:var(--space-xl) 0}.comparison-card{background:var(--color-surface);padding:var(--space-lg);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);text-align:center}.comparison-card.positive{border-top:4px solid var(--color-success)}.comparison-card.negative{border-top:4px solid var(--color-error)}.comparison-label{font-size:var(--font-size-sm);color:var(--color-text-secondary);margin-bottom:var(--space-sm)}.comparison-value{font-size:var(--font-size-2xl);font-weight:var(--font-weight-bold);margin-bottom:var(--space-xs)}.comparison-percentage{font-size:var(--font-size-sm);font-weight:var(--font-weight-medium)}.badge{display:inline-block;padding:var(--space-xs) var(--space-sm);border-radius:var(--radius-md);font-size:var(--font-size-xs);font-weight:var(--font-weight-medium);text-transform:uppercase;letter-spacing:.5px}.badge-donation{background:var(--color-success-light);color:var(--color-success-dark)}.badge-sponsorship{background:var(--color-info-light);color:var(--color-info-dark)}.badge-grant{background:var(--color-warning-light);color:var(--color-warning-dark)}.badge-other{background:var(--color-surface-secondary);color:var(--color-text-secondary)}.summary-card.primary{border-top:4px solid var(--color-primary)}.summary-card.info-card{border-top:4px solid var(--color-info)}.summary-card.action-card{background:transparent;box-shadow:none;padding:0}.summary-card .card-detail{font-size:var(--font-size-sm);color:var(--color-text-secondary);margin-top:var(--space-xs)}@media(max-width:768px){.filters-row{grid-template-columns:1fr}.filter-actions{grid-column:1}.date-range-inputs{grid-template-columns:1fr}.action-buttons{flex-direction:column}.action-buttons .btn{width:100%}.chart-bar-item{grid-template-columns:1fr;gap:var(--space-sm)}.chart-percentage{text-align:left}.comparison-summary{grid-template-columns:1fr}.source-summary{flex-direction:column;align-items:flex-start;gap:var(--space-sm)}.revenue-table,.expense-table,.data-table{display:block;overflow-x:auto;white-space:nowrap}.grid-2{grid-template-columns:1fr}}@media(prefers-reduced-motion:reduce){*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}}.equipment-selection{display:flex;flex-direction:column;gap:var(--space-sm)}.equipment-item{padding:var(--space-sm);border:1px solid var(--color-border);border-radius:var(--radius-sm);background:var(--color-surface);transition:background-color .2s ease}.equipment-item:hover{background:var(--color-surface-secondary)}.equipment-checkbox{display:flex;align-items:center;gap:var(--space-xs);cursor:pointer;font-weight:500}.equipment-checkbox input[type=checkbox]{width:20px;height:20px;cursor:pointer}.equipment-name{font-weight:600;color:var(--color-text)}.equipment-category{color:var(--color-text-secondary);font-size:var(--font-size-sm);margin-left:var(--space-xs)}.equipment-available{color:var(--color-text-muted);font-size:var(--font-size-sm);margin-left:auto}.quantity-input{display:flex;align-items:center;gap:var(--space-xs);margin-top:var(--space-xs);margin-left:var(--space-lg)}.quantity-input input[type=number]{width:80px}.selected-items-list{list-style:none;padding:0;margin:var(--space-sm) 0}.selected-items-list li{padding:var(--space-xs);border-bottom:1px solid var(--color-border-light)}.selected-items-list li:last-child{border-bottom:none}@media(max-width:768px){.equipment-checkbox{flex-wrap:wrap}.equipment-available{margin-left:0;width:100%}.quantity-input{margin-left:var(--space-md)}}.form-builder{max-width:1400px;margin:0 auto;padding:1rem}.form-builder-toolbar{margin:1rem 0;display:flex;gap:.5rem;flex-wrap:wrap}.form-formats-list{margin:2rem 0}.formats-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1rem;margin-top:1rem}.format-card{background:#fff;border:1px solid #ddd;border-radius:8px;padding:1rem;box-shadow:0 2px 4px #0000001a;transition:transform .2s,box-shadow .2s}.format-card:hover{transform:translateY(-2px);box-shadow:0 4px 8px #00000026}.format-card h3{margin:0 0 .5rem;font-size:1.2rem;color:#333}.format-meta{color:#666;font-size:.9rem;margin:.5rem 0}.format-actions{display:flex;gap:.5rem;margin-top:1rem}.form-editor{background:#fff;border:1px solid #ddd;border-radius:8px;padding:1.5rem;margin:2rem 0;box-shadow:0 2px 8px #0000001a}.editor-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem;flex-wrap:wrap;gap:1rem}.editor-header h2{margin:0;flex:1;min-width:200px}.editor-actions{display:flex;gap:.5rem;flex-wrap:wrap}.fields-list{margin-top:1.5rem}.fields-list h3{margin-bottom:1rem}.fields-container{margin-top:1rem}.fields-sortable{display:flex;flex-direction:column;gap:.5rem}.field-item{display:flex;align-items:center;background:#f8f9fa;border:2px solid #dee2e6;border-radius:6px;padding:.75rem;gap:.75rem;cursor:move;transition:all .2s}.field-item:focus{outline:2px solid #0066cc;outline-offset:2px}.field-item.dragging{opacity:.5;background:#e9ecef}.field-item.drag-over{border-color:#06c;background:#e3f2fd}.field-handle{cursor:grab;font-size:1.2rem;color:#666;user-select:none}.field-handle:active{cursor:grabbing}.field-info{flex:1;min-width:0;display:flex;flex-wrap:wrap;gap:.5rem;align-items:center}.field-info strong{font-weight:600;color:#333}.field-type{color:#666;font-size:.9rem;font-style:italic}.field-actions{display:flex;gap:.25rem}.btn-icon{background:none;border:1px solid #ccc;border-radius:4px;padding:.25rem .5rem;cursor:pointer;font-size:1rem;transition:all .2s;min-width:32px;min-height:32px}.btn-icon:hover:not(:disabled){background:#f0f0f0;border-color:#999}.btn-icon:disabled{opacity:.5;cursor:not-allowed}.badge{display:inline-block;padding:.25rem .5rem;font-size:.75rem;font-weight:600;border-radius:4px;background:#007bff;color:#fff}.badge-info{background:#17a2b8}.badge-warning{background:#ffc107;color:#333}.field-editor-form .form-group{margin-bottom:1.25rem}.field-editor-form label{display:block;font-weight:600;margin-bottom:.5rem;color:#333}.field-editor-form input[type=text],.field-editor-form input[type=email],.field-editor-form textarea,.field-editor-form select{width:100%;padding:.5rem;border:1px solid #ccc;border-radius:4px;font-size:1rem;font-family:inherit}.field-editor-form input[type=text]:focus,.field-editor-form input[type=email]:focus,.field-editor-form textarea:focus,.field-editor-form select:focus{outline:none;border-color:#06c;box-shadow:0 0 0 3px #0066cc1a}.field-editor-form small{display:block;margin-top:.25rem;color:#666;font-size:.85rem}.input-with-button{display:flex;gap:.5rem}.input-with-button input{flex:1}.input-with-button .btn{white-space:nowrap}.option-item{display:flex;gap:.5rem;margin-bottom:.5rem;align-items:center}.option-item input{flex:1;min-width:0}.option-item .btn-icon{flex-shrink:0}.no-options{color:#666;font-style:italic;padding:.5rem}.form-actions{display:flex;gap:.5rem;margin-top:1.5rem;padding-top:1rem;border-top:1px solid #ddd}.no-data{color:#666;font-style:italic;text-align:center;padding:2rem;background:#f8f9fa;border-radius:6px;border:1px dashed #ccc}@media(max-width:768px){.form-builder{padding:.5rem}.formats-grid{grid-template-columns:1fr}.editor-header{flex-direction:column;align-items:stretch}.editor-actions{width:100%}.editor-actions .btn{flex:1}.field-item{flex-wrap:wrap}.field-actions{width:100%;justify-content:flex-end}.modal-content{width:95%;margin:2% auto;padding:1rem}.form-actions{flex-direction:column}.form-actions .btn{width:100%}.option-item{flex-wrap:wrap}.input-with-button{flex-direction:column}.input-with-button .btn{width:100%}}@media(prefers-contrast:high){.field-item{border-width:3px}.btn{border:2px solid currentColor}}@media(prefers-reduced-motion:reduce){.field-item,.format-card,.btn,.modal,.modal-content{transition:none;animation:none}}.payment-modal{max-width:600px;width:90%}.payment-info{background-color:var(--color-bg-secondary, #f5f5f5);border-radius:8px;padding:1rem;margin-bottom:1.5rem}.payment-info p{margin:.5rem 0;color:var(--color-text-primary, #333)}.payment-form-container{margin:1.5rem 0}#payment-element{margin-bottom:1rem}.payment-actions{display:flex;gap:1rem;justify-content:flex-end;margin-top:1.5rem;padding-top:1rem;border-top:1px solid var(--color-border, #e0e0e0)}.payment-actions button{flex:0 1 auto}.payment-btn-spinner{display:inline-flex;align-items:center;gap:.5rem}.payment-btn-spinner .spinner{display:inline-block;width:16px;height:16px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .6s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.error-message{color:var(--color-error, #d32f2f);font-size:.9rem;margin-top:.5rem;padding:.5rem;background-color:#d32f2f1a;border-radius:4px;display:none}.error-message:not(:empty){display:block}.not-found-state{display:flex;justify-content:center;padding:2rem 1rem}.not-found-state__card{width:100%;max-width:520px;background:#fff;border:1px solid var(--color-border, #e0e0e0);border-radius:12px;padding:1.5rem;text-align:center;box-shadow:0 8px 24px #0000000f}.not-found-state__message{margin:.75rem 0 0;color:var(--color-text-muted, #666)}.not-found-state__detail{margin:.5rem 0 0;color:var(--color-text-muted, #666);font-weight:600}.not-found-state__actions{margin-top:1.25rem;display:flex;justify-content:center}.finance-actions{margin-top:1rem;padding-top:1rem;border-top:1px solid var(--color-border, #e0e0e0)}.pay-now-btn{width:100%;max-width:300px}@media(max-width:768px){.payment-modal{width:95%;max-width:none}.payment-actions{flex-direction:column-reverse}.payment-actions button{width:100%}.pay-now-btn{max-width:none}}@media(prefers-reduced-motion:reduce){.payment-btn-spinner .spinner{animation:none;opacity:.5}}.form-permissions-manager{max-width:1400px;margin:0 auto;padding:var(--space-lg)}.permissions-container{margin-top:var(--space-xl)}.permissions-matrix{display:flex;flex-direction:column;gap:var(--space-xl)}.form-section{background:var(--color-surface);border-radius:var(--radius-lg);padding:var(--space-lg);box-shadow:var(--shadow-base)}.form-section__title{font-size:var(--font-size-lg);font-weight:var(--font-weight-semibold);color:var(--color-primary);margin-bottom:var(--space-md);padding-bottom:var(--space-sm);border-bottom:2px solid var(--color-border-light)}.permissions-table-wrapper{overflow-x:auto;margin-top:var(--space-md)}.permissions-table{width:100%;border-collapse:collapse;background:var(--color-surface)}.permissions-table thead{background:var(--color-secondary)}.permissions-table th{padding:var(--space-md);text-align:left;font-weight:var(--font-weight-semibold);color:var(--color-text);border-bottom:2px solid var(--color-border);font-size:var(--font-size-sm);text-transform:uppercase;letter-spacing:.05em}.permissions-table td{padding:var(--space-md);border-bottom:1px solid var(--color-border-light)}.permissions-table tbody tr:hover{background:var(--color-background);transition:background var(--transition-fast)}.permissions-table .role-name{font-weight:var(--font-weight-medium);color:var(--color-text)}.permission-checkbox{cursor:pointer;width:20px;height:20px;accent-color:var(--color-primary);margin:0}.permission-checkbox:disabled{cursor:not-allowed;opacity:.5}@media(max-width:768px){.form-permissions-manager{padding:var(--space-md)}.permissions-table{font-size:var(--font-size-sm)}.permissions-table th,.permissions-table td{padding:var(--space-sm)}.form-section{padding:var(--space-md)}}.permission-checkbox:focus{outline:2px solid var(--color-primary);outline-offset:2px}.display-context-section{background:var(--color-background);padding:var(--space-md);border-radius:var(--radius-md);margin-bottom:var(--space-lg)}.display-context-title{font-size:var(--font-size-base);font-weight:var(--font-weight-semibold);color:var(--color-text);margin-bottom:var(--space-sm)}.display-context-description{font-size:var(--font-size-sm);color:var(--color-text-muted);margin-bottom:var(--space-md)}.context-checkboxes{display:flex;flex-wrap:wrap;gap:var(--space-md)}.context-checkbox-label{display:flex;align-items:center;gap:var(--space-sm);cursor:pointer;padding:var(--space-sm) var(--space-md);background:var(--color-surface);border:2px solid var(--color-border);border-radius:var(--radius-sm);transition:all var(--transition-fast)}.context-checkbox-label:hover{border-color:var(--color-primary);background:var(--color-secondary)}.context-checkbox-label input[type=checkbox]:checked+span{color:var(--color-primary);font-weight:var(--font-weight-medium)}.context-checkbox{cursor:pointer;width:18px;height:18px;accent-color:var(--color-primary)}.permissions-subtitle{font-size:var(--font-size-base);font-weight:var(--font-weight-semibold);color:var(--color-text);margin-bottom:var(--space-md);margin-top:var(--space-md)}@media(max-width:768px){.context-checkboxes{flex-direction:column}.context-checkbox-label{width:100%}}.achievement-modal-content{max-inline-size:700px}.achievement-modal__type-selection{margin-block-end:var(--space-lg)}.achievement-modal__type-selection label{display:block;font-weight:var(--font-weight-semibold);margin-block-end:var(--space-sm)}.achievement-modal__type-buttons{display:flex;gap:var(--space-sm)}.achievement-type-btn{padding:var(--space-sm) var(--space-lg);border:2px solid var(--color-border);background-color:var(--color-surface);color:var(--color-text);border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast);font-weight:var(--font-weight-medium);min-inline-size:100px}.achievement-type-btn:hover{border-color:var(--color-primary);background-color:var(--color-secondary)}.achievement-type-btn.active{background-color:var(--color-primary);border-color:var(--color-primary);color:#fff}.achievement-modal__badges,.achievement-modal__participants{margin-block-end:var(--space-lg)}.achievement-modal__badges>label,.achievement-modal__participants>label{display:block;font-weight:var(--font-weight-semibold);margin-block-end:var(--space-sm)}.achievement-badge-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(100px,1fr));gap:var(--space-md);max-block-size:250px;overflow-y:auto;padding:var(--space-sm);border:1px solid var(--color-border-light);border-radius:var(--radius-md);background-color:var(--color-background)}.achievement-badge-card{display:flex;flex-direction:column;align-items:center;gap:var(--space-xs);padding:var(--space-sm);border:2px solid var(--color-border);border-radius:var(--radius-md);background-color:var(--color-surface);cursor:pointer;transition:all var(--transition-fast);text-align:center}.achievement-badge-card:hover{border-color:var(--color-primary-light);background-color:var(--color-secondary)}.achievement-badge-card.selected{border-color:var(--color-primary);background-color:var(--color-secondary);box-shadow:0 0 0 2px var(--color-primary)}.achievement-badge-card__image{inline-size:48px;block-size:48px;object-fit:contain;border-radius:var(--radius-sm)}.achievement-badge-card__placeholder{inline-size:48px;block-size:48px;display:flex;align-items:center;justify-content:center;font-size:24px;color:var(--color-primary);background-color:var(--color-secondary);border-radius:var(--radius-sm)}.achievement-badge-card__name{font-size:var(--font-size-xs);font-weight:var(--font-weight-medium);color:var(--color-text);max-inline-size:100%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.achievement-participant-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:var(--space-sm);max-block-size:200px;overflow-y:auto;padding:var(--space-sm);border:1px solid var(--color-border-light);border-radius:var(--radius-md);background-color:var(--color-background)}.achievement-participant-item{display:flex;align-items:center;gap:var(--space-sm);padding:var(--space-xs) var(--space-sm);border-radius:var(--radius-sm);background-color:var(--color-surface);cursor:pointer;transition:background-color var(--transition-fast);font-size:var(--font-size-sm)}.achievement-participant-item:hover{background-color:var(--color-secondary)}.achievement-participant-checkbox{accent-color:var(--color-primary)}.achievement-modal__empty{color:var(--color-text-muted);font-style:italic;padding:var(--space-md);text-align:center}.modal-actions{display:flex;justify-content:flex-end;gap:var(--space-md);padding:var(--space-md) var(--space-lg);border-block-start:1px solid var(--color-border)}@media(max-width:600px){.achievement-badge-grid{grid-template-columns:repeat(auto-fill,minmax(80px,1fr))}.achievement-participant-grid{grid-template-columns:1fr}.achievement-modal__type-buttons{flex-direction:column}.achievement-type-btn{inline-size:100%}}.achievement-summary{padding:var(--space-sm) var(--space-md);margin-inline-start:40px;margin-block-end:var(--space-sm);background:linear-gradient(135deg,#fff9e6,#fff3cc);border-inline-start:3px solid #ffd700;border-radius:var(--radius-sm)}.achievement-summary.hidden{display:none}.achievement-summary__content{display:flex;align-items:center;gap:var(--space-md);flex-wrap:wrap}.achievement-summary__image{inline-size:32px;block-size:32px;object-fit:contain;border-radius:var(--radius-sm)}.achievement-summary__details{display:flex;align-items:center;gap:var(--space-sm);flex-wrap:wrap;font-size:var(--font-size-sm)}.achievement-summary__badge{font-weight:var(--font-weight-semibold);color:var(--color-primary-dark)}.achievement-summary__type{color:var(--color-text-muted);font-style:italic}.achievement-summary__participants{color:var(--color-text)}
