:root{--bg:#eff4f8;--bg-strong:#dce9f3;--surface:rgba(255,255,255,0.86);--surface-strong:#ffffff;--ink:#10233a;--muted:#5f6f82;--line:rgba(16,35,58,0.12);--primary:#0f4c81;--primary-strong:#0a3559;--accent:#d62839;--success:#157f5b;--shadow:0 22px 60px rgba(16,35,58,0.12)}*{box-sizing:border-box}:focus-visible{outline:3px solid var(--primary);outline-offset:2px;border-radius:4px}:focus:not(:focus-visible){outline:none}@media (prefers-reduced-motion:reduce){*,:after,:before{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important;scroll-behavior:auto!important}}html{min-height:100%}body{margin:0;min-height:100vh;color:var(--ink);background:radial-gradient(circle at top left,rgba(214,40,57,.12),transparent 30%),radial-gradient(circle at top right,rgba(15,76,129,.18),transparent 28%),linear-gradient(180deg,#f7fbff 0,var(--bg) 40%,#edf2f7 100%);font-family:Segoe UI,Trebuchet MS,sans-serif}a{color:inherit;text-decoration:none}.field-error{display:block;margin-top:4px;font-size:.8rem;color:#dc2626;font-weight:500}.page-shell{min-height:100vh}.page-main{width:min(1200px,calc(100% - 32px));margin:0 auto;padding:24px 0 48px}.page-main-editor{width:min(1840px,calc(100% - 8px))}.page-main-calendar{width:min(1440px,calc(100% - 32px))}.nav{position:-webkit-sticky;position:sticky;top:0;z-index:20;justify-content:space-between;gap:12px;padding:14px 22px;-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px);background:rgba(247,251,255,.84);border-bottom:1px solid rgba(16,35,58,.08)}.brand,.nav{display:flex;align-items:center}.brand{gap:14px}.brand strong{display:block;font-size:1rem}.brand p{margin:2px 0 0;color:var(--muted);font-size:.88rem}.brand-mark{display:grid;place-items:center;width:48px;height:48px;border-radius:16px;background:linear-gradient(145deg,var(--accent),#ef4444);color:white;font-weight:800;letter-spacing:.08em;box-shadow:var(--shadow)}.brand-logo .nav-brand-logo-img{height:64px;width:auto;display:block;object-fit:fill}.brand-logo{width:52px;height:52px;border-radius:0;overflow:visible;flex-shrink:0;display:flex;align-items:center;justify-content:center}.brand-logo img{width:56px;height:56px;object-fit:contain;display:block;filter:drop-shadow(0 2px 8px rgba(16,35,58,.18)) drop-shadow(0 1px 2px rgba(16,35,58,.1))}.nav-links{display:flex;flex-wrap:wrap;gap:4px;align-items:center}.nav-link{padding:8px 10px;border-radius:999px;color:var(--muted);font-size:.92rem;white-space:nowrap;transition:background-color .16s ease,color .16s ease,transform .16s ease}.nav-link:hover{background:rgba(15,76,129,.08);color:var(--ink);transform:translateY(-1px)}.nav-link-active{background:rgba(15,76,129,.12);color:var(--primary-strong)}.nav-user{gap:8px}.nav-user,.nav-user-label{display:inline-flex;align-items:center}.nav-user-label{min-height:40px;max-width:220px;padding:0 14px;border-radius:999px;background:rgba(16,35,58,.06);color:var(--ink);font-size:.88rem;font-weight:700;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.hero{display:flex;align-items:flex-end;justify-content:space-between;gap:20px;padding:10px 0 18px}.hero h1{margin:6px 0 0;font-size:clamp(2rem,4vw,3.3rem);line-height:1;max-width:14ch}.hero-title-compact{font-size:clamp(1.8rem,3vw,2.7rem)}.hero-title-nowrap{max-width:none;white-space:nowrap}.eyebrow{display:inline-flex;align-items:center;gap:8px;font-size:.8rem;font-weight:700;text-transform:uppercase;letter-spacing:.14em;color:var(--primary)}.hero-actions{display:flex;flex-wrap:wrap;gap:12px}.button,.button-secondary{display:inline-flex;align-items:center;justify-content:center;gap:8px;min-height:48px;padding:0 18px;border-radius:14px;border:0;cursor:pointer;font-size:.96rem;font-weight:700}.button{background:linear-gradient(135deg,var(--primary),var(--primary-strong));color:white;box-shadow:var(--shadow)}.button-secondary{background:rgba(255,255,255,.74);color:var(--ink);border:1px solid rgba(16,35,58,.08)}.button-secondary:disabled,.button:disabled{opacity:.45;cursor:not-allowed}.grid{display:grid;grid-gap:16px;gap:16px}.grid.cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}.grid.cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}.card{background:var(--surface);border:1px solid rgba(255,255,255,.6);border-radius:24px;padding:20px;box-shadow:var(--shadow)}.card-header{gap:16px;margin-bottom:18px}.card h2{margin:0;font-size:1.1rem}.card-title-compact{font-size:1rem}.card-title-nowrap{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.card p{margin:6px 0 0;color:var(--muted)}.stats{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));grid-gap:16px;gap:16px}.stat{padding:18px;border-radius:18px;background:linear-gradient(180deg,rgba(255,255,255,.86),rgba(220,233,243,.75));border:1px solid var(--line)}.stat strong{display:block;font-size:2rem;line-height:1}.stat span{display:block;margin-top:8px;color:var(--muted)}.list{display:grid;grid-gap:12px;gap:12px}.card-actions{display:flex;flex-wrap:wrap;gap:7px;margin-top:14px}.card-actions .button,.card-actions .button-secondary{font-size:.8rem;padding:5px 11px;min-height:30px;border-radius:10px}.card-actions .danger-action{font-size:.8rem}.danger-action{color:var(--accent)}.list-item{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:14px 16px;border-radius:18px;background:rgba(255,255,255,.72);border:1px solid var(--line)}.item-title{font-weight:700}.practice-drill-card{min-height:110px}.item-meta{color:var(--muted);font-size:.92rem}.tags{display:flex;flex-wrap:wrap;gap:8px}.tag{display:inline-flex;align-items:center;min-height:28px;padding:0 10px;border-radius:999px;background:rgba(15,76,129,.08);color:var(--primary-strong);font-size:.8rem;font-weight:700}.layout-split{display:grid;grid-template-columns:2.2fr 1fr;grid-gap:16px;gap:16px}.layout-split-equal{grid-template-columns:1fr 1fr;align-items:stretch}.layout-split-equal,.practice-builder{display:grid;grid-gap:16px;gap:16px}.print-page{padding:14px;background:#edf2f7}.print-toolbar{display:flex;gap:10px;justify-content:flex-end;margin-bottom:10px}.print-sheet{width:min(1180px,100%);margin:0 auto;padding:18px 22px;border-radius:18px;background:white;box-shadow:var(--shadow)}.print-header{display:flex;align-items:flex-start;justify-content:space-between;gap:14px;padding-bottom:10px;border-bottom:2px solid rgba(16,35,58,.08)}.print-header h1{margin:4px 0;font-size:1.45rem}.print-header p{margin:0;color:var(--muted)}.print-summary{display:flex;gap:8px}.print-stat{min-width:86px;padding:9px 12px;border-radius:14px;background:rgba(15,76,129,.06);text-align:center}.print-stat strong{display:block;font-size:1.25rem}.print-stat span{color:var(--muted);font-size:.9rem}.print-block{margin-top:12px}.print-block h2{margin:0 0 8px;font-size:1.15rem}.print-timeline{display:grid;grid-gap:5px;gap:5px}.print-timeline-item{display:flex;justify-content:space-between;gap:10px;padding:7px 10px;border-radius:10px;background:rgba(15,76,129,.05);font-size:.88rem}.print-drill-list{display:grid;grid-gap:8px;gap:8px}.print-drill-card{display:grid;grid-template-columns:minmax(160px,.58fr) minmax(0,1.42fr);grid-gap:10px;gap:10px;padding:9px 10px;border-radius:14px;border:1px solid rgba(16,35,58,.08);break-inside:avoid;page-break-inside:avoid}.print-step{display:inline-block;margin-bottom:5px;color:var(--accent);font-size:.66rem;font-weight:800;text-transform:uppercase;letter-spacing:.08em}.print-drill-copy h3{margin:0 0 4px;font-size:1rem}.print-drill-copy p{margin:0 0 6px;color:var(--muted);font-size:.82rem;line-height:1.25}.print-meta{display:flex;flex-wrap:wrap;gap:5px}.print-meta span{padding:4px 8px;border-radius:999px;background:rgba(15,76,129,.08);color:var(--primary-strong);font-size:.72rem;font-weight:700}.print-drill-rink-phases{display:grid;grid-gap:6px;gap:6px}.print-drill-phase{display:grid;grid-gap:3px;gap:3px}.print-drill-phase h4{margin:0;color:var(--primary-strong);font-size:.78rem}.print-drill-phase .rink-wrap{gap:0}.print-drill-phase .rink-svg{display:block;max-height:148px;border-radius:0;background:transparent}.print-drill-phase .rink-svg-portrait{width:auto;max-height:148px;display:block;margin:0 auto}.editor-layout{display:grid;grid-template-columns:240px minmax(0,1fr) 320px;grid-gap:16px;gap:16px}.editor-layout-wide{grid-template-columns:210px minmax(0,1.65fr) 280px;gap:14px;align-items:start}.panel{background:var(--surface);border-radius:24px;border:1px solid rgba(255,255,255,.6);padding:18px;box-shadow:var(--shadow)}.panel h3{margin:0 0 14px;font-size:1rem}.editor-panel{position:-webkit-sticky;position:sticky;top:92px}.text-inline-editor{min-width:120px;max-width:320px;padding:6px 12px;font-size:1rem;font-weight:600;text-align:center;border:2px solid var(--primary);border-radius:8px;background:rgba(255,255,255,.96);color:#0f1923;box-shadow:0 4px 20px rgba(15,76,129,.25);outline:none;pointer-events:auto}.tool-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));grid-gap:8px;gap:8px}.tool{min-height:52px;padding:10px 12px;border-radius:12px;border:1px solid var(--line);background:rgba(255,255,255,.78);font-weight:700;text-align:left}.tool-active{background:linear-gradient(135deg,rgba(15,76,129,.14),rgba(214,40,57,.08));border-color:rgba(15,76,129,.3)}.rink-wrap{display:grid;grid-gap:12px;gap:12px}.rink-label{justify-self:start;padding:8px 10px;border-radius:999px;background:rgba(214,40,57,.1);color:var(--accent);font-size:.78rem;font-weight:800;text-transform:uppercase;letter-spacing:.08em}.rink-svg{width:100%;height:auto;border-radius:28px;overflow:hidden;background:radial-gradient(ellipse 75% 55% at 50% 38%,rgba(255,255,255,.96) 0,transparent 100%),linear-gradient(170deg,rgba(236,248,255,.97),rgba(218,239,253,.98) 55%,rgba(208,232,250,.97))}.rink-svg-interactive{cursor:crosshair;-webkit-user-select:none;-moz-user-select:none;user-select:none;touch-action:none}.rink-svg-editor{display:block;width:min(100%,calc((100vh - 250px) * 2));min-height:0;margin:0 auto}.rink-svg-editor-portrait{min-height:338px;max-height:410px}.rink-svg-editor-half-portrait{width:min(100%,520px);height:auto;max-height:none;min-height:0}.rink-svg-editor-half-landscape{width:min(100%,500px)}.rink-svg-portrait{max-height:360px;width:auto;display:block;margin:0 auto}.field-list{display:grid;grid-gap:12px;gap:12px}.calendar-import-box{display:grid;grid-gap:10px;gap:10px;padding:14px;border-radius:18px;border:1px solid rgba(15,76,129,.12);background:linear-gradient(135deg,rgba(15,76,129,.08),rgba(255,255,255,.9))}.calendar-import-box strong{display:block;margin-bottom:4px;color:var(--ink)}.calendar-import-box p{margin:0;color:var(--muted);font-size:.86rem;line-height:1.4}.calendar-import-button{width:100%;cursor:pointer}.calendar-import-button input{display:none}.calendar-import-button-disabled{cursor:wait;opacity:.72}.calendar-top-actions{position:relative;display:flex;justify-content:flex-end;min-height:44px}.calendar-import-toggle{min-height:42px;padding:0 18px;border-radius:16px;font-size:.9rem}.calendar-import-popover{position:absolute;top:48px;right:0;z-index:20;display:grid;grid-gap:10px;gap:10px;width:min(320px,calc(100vw - 48px));padding:14px;border:1px solid rgba(16,35,58,.1);border-radius:18px;background:rgba(255,255,255,.98);box-shadow:var(--shadow)}.calendar-import-popover-header{display:flex;align-items:center;justify-content:space-between}.calendar-import-popover-title{font-size:.85rem;font-weight:600;color:var(--text)}.calendar-import-popover-close{background:none;border:none;cursor:pointer;color:var(--muted);font-size:.9rem;padding:2px 6px;border-radius:6px;line-height:1;transition:color .15s,background .15s}.calendar-import-popover-close:hover{color:var(--text);background:rgba(0,0,0,.06)}.calendar-import-message{margin:0;color:var(--muted);font-size:.84rem;line-height:1.35}.calendar-import-hint{margin:0!important;color:var(--muted)!important;font-size:.78rem!important;opacity:.6}.calendar-import-popover p{margin:0;color:var(--muted);font-size:.84rem;line-height:1.35}.calendar-active-actions{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));grid-gap:8px;gap:8px}.calendar-active-actions button:last-child{grid-column:1/-1}.calendar-status-box{min-height:48px;white-space:normal}.calendar-panel-inactive{display:grid;grid-gap:12px;gap:12px}.calendar-panel-hint{margin:0;font-size:.88rem;color:var(--muted)}.month-calendar-cell-clickable{cursor:pointer}.month-calendar-cell-clickable:hover{background:rgba(255,255,255,.04);border-radius:8px}.month-calendar-cell-selected{background:rgba(15,76,129,.18)!important;border-radius:8px;outline:2px solid var(--primary);outline-offset:-2px}.week-calendar-day-clickable{cursor:pointer;transition:background .15s}.week-calendar-day-clickable:hover{background:rgba(255,255,255,.96)}.week-calendar-day-selected{background:rgba(15,76,129,.1)!important;border:2px solid var(--primary)!important}.week-calendar-day-selected.week-calendar-day-clickable:hover{background:rgba(15,76,129,.14)!important}.game-teams-row{display:flex;align-items:flex-end;gap:12px}.game-teams-vs{font-size:1.5rem;font-weight:800;color:var(--muted);padding-bottom:10px;flex-shrink:0}.game-preview-title{text-align:center;font-size:1.1rem;font-weight:700;color:var(--primary-strong);padding:8px 0;border-top:1px solid rgba(0,0,0,.07)}.practice-history-list-scroll{max-height:480px;min-height:480px;overflow-y:auto;padding-right:4px}.month-calendar-event-plan{font-size:.65rem;opacity:.8;overflow:hidden;white-space:nowrap;text-overflow:ellipsis}.practice-history-item-compact{gap:6px;padding:10px 0}.field{display:grid;grid-gap:6px;gap:6px}.field label{font-size:.84rem;font-weight:700;color:var(--muted)}.field .input{min-height:46px;padding:12px 14px;border:1px solid var(--line);border-radius:14px;background:rgba(255,255,255,.82);width:100%;color:var(--ink);font:inherit}.history-actions,.property-row{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));grid-gap:10px;gap:10px}.editor-tool-section{display:grid;grid-gap:10px;gap:10px;margin-bottom:16px;padding-bottom:16px;border-bottom:1px solid rgba(16,35,58,.08)}.editor-tool-section:last-child{margin-bottom:0;padding-bottom:0;border-bottom:0}.editor-tool-section-title{font-size:.84rem;font-weight:800;letter-spacing:.08em;text-transform:uppercase;color:var(--muted)}.editor-details-header{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-bottom:14px}.editor-details-actions{display:flex;flex-wrap:wrap;justify-content:flex-end;gap:8px}.editor-tags-button{min-height:38px;padding:0 12px;font-size:.84rem}.editor-shortcut-manager{display:grid;grid-gap:12px;gap:12px;max-height:420px;overflow:auto;padding:14px;margin-bottom:14px;border-radius:16px;background:rgba(15,76,129,.06);border:1px solid rgba(16,35,58,.08)}.editor-shortcut-header{display:grid;grid-gap:3px;gap:3px}.editor-shortcut-header strong,.editor-shortcut-section h4{color:var(--ink)}.editor-shortcut-header span{color:var(--muted);font-size:.86rem}.editor-shortcut-list,.editor-shortcut-section{display:grid;grid-gap:8px;gap:8px}.editor-shortcut-section{padding-top:10px;border-top:1px solid rgba(16,35,58,.08)}.editor-shortcut-section h4{margin:0;font-size:.82rem;letter-spacing:.06em;text-transform:uppercase}.editor-shortcut-row{gap:6px}.editor-shortcut-row,.editor-shortcut-tool{display:flex;align-items:center;min-width:0}.editor-shortcut-tool{flex:1 1;gap:5px;overflow:hidden}.editor-shortcut-tool span{display:grid;place-items:center;width:24px;height:24px;flex:0 0 24px;border-radius:7px;background:rgba(255,255,255,.8);border:1px solid rgba(16,35,58,.08)}.editor-shortcut-tool strong{overflow:hidden;color:var(--ink);font-size:.8rem;text-overflow:ellipsis;white-space:nowrap;flex:1 1;min-width:0}.editor-shortcut-input{width:38px;flex:0 0 38px;min-height:32px;padding:0;text-align:center;font-weight:900;font-size:.85rem}.editor-shortcut-clear-btn{flex:0 0 24px;width:24px;height:24px;border-radius:50%;border:none;background:transparent;color:var(--muted);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .12s,color .12s;padding:0}.editor-shortcut-clear-btn:hover{background:rgba(214,40,57,.1);color:var(--accent)}.editor-tag-manager{display:grid;grid-gap:12px;gap:12px;padding:14px;border-radius:16px;background:rgba(15,76,129,.06);border:1px solid rgba(16,35,58,.08);min-width:0;overflow:hidden}.editor-tag-remove-x{flex-shrink:0;width:24px;height:24px;border-radius:50%;border:none;background:transparent;color:var(--accent);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .12s;padding:0}.editor-tag-remove-x:hover{background:rgba(214,40,57,.1)}.editor-tag-creator{display:grid;grid-template-columns:minmax(0,1fr) auto;grid-gap:10px;gap:10px}.editor-tag-option-list{display:grid;grid-gap:8px;gap:8px}.editor-tag-option-row{display:flex;align-items:center;justify-content:space-between;gap:6px;min-width:0}.editor-tag-option-row .tag-button{flex:1 1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.editor-tag-remove{min-height:34px;padding:0 10px}.input-color{min-height:52px;padding:8px}.textarea{min-height:104px;resize:vertical}.segmented{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));grid-gap:8px;gap:8px}.segmented-button{min-height:42px;border-radius:12px;border:1px solid var(--line);background:rgba(255,255,255,.72);color:var(--ink);font-weight:700;text-transform:capitalize}.segmented-button-active{background:rgba(15,76,129,.12);border-color:rgba(15,76,129,.3)}.tag-button{display:inline-flex;align-items:center;justify-content:center;min-height:34px;padding:0 12px;border-radius:999px;border:1px solid rgba(15,76,129,.12);background:rgba(255,255,255,.82);color:var(--primary-strong);font-size:.82rem;font-weight:700}.tag-button-active{background:rgba(15,76,129,.12);border-color:rgba(15,76,129,.28)}.timeline{display:grid;grid-gap:12px;gap:12px}.timeline-item{display:grid;grid-gap:6px;gap:6px;padding:14px 16px;border-radius:18px;border:1px solid var(--line);background:rgba(255,255,255,.74)}.calendar-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));grid-gap:16px;gap:16px}.calendar-grid-wide{grid-template-columns:repeat(2,minmax(0,1fr))}.calendar-day{padding:16px;border-radius:20px;border:1px solid var(--line);background:rgba(255,255,255,.72)}.calendar-day h3{margin:0 0 12px}.calendar-event-card{align-items:flex-start}.calendar-event-actions{display:grid;grid-gap:8px;gap:8px;justify-items:end}.badge{display:inline-flex;align-items:center;min-height:24px;padding:0 8px;border-radius:999px;font-size:.75rem;font-weight:800;letter-spacing:.04em;text-transform:uppercase}.badge.practice{background:rgba(21,127,91,.12);color:var(--success)}.badge.game{background:rgba(214,40,57,.12);color:var(--accent)}.badge.meeting{background:rgba(15,76,129,.12);color:var(--primary)}.dashboard-layout{display:grid;grid-template-columns:minmax(0,1fr) 280px;grid-gap:18px;gap:18px;align-items:start}.dashboard-calendar-card,.dashboard-info-card{background:rgba(255,255,255,.92);border:1px solid rgba(16,35,58,.08);border-radius:24px;padding:20px;box-shadow:var(--shadow)}.dashboard-side-column{display:grid;grid-gap:16px;gap:16px}.month-calendar-header{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:16px}.month-calendar-header h2{margin:0;font-size:clamp(1.5rem,2.3vw,2.4rem);letter-spacing:.08em;text-align:center}.month-nav-button{min-width:92px}.month-calendar-grid{display:grid;grid-template-columns:repeat(7,minmax(0,1fr));border:2px solid rgba(16,35,58,.28);background:white;min-width:0;width:100%}.month-calendar-grid-compact .month-calendar-weekday{min-height:46px;font-size:.72rem;padding:6px}.month-calendar-grid-compact .month-calendar-cell{min-height:118px;padding:8px}.month-calendar-grid-compact .month-calendar-day-number{font-size:1.1rem}.month-calendar-grid-compact .month-calendar-event{padding:6px 8px}@media (max-width:520px){.month-calendar-cell{min-height:72px;padding:5px 4px}.month-calendar-grid-compact .month-calendar-cell{min-height:64px;padding:4px}.month-calendar-day-number{font-size:.9rem}.month-calendar-weekday{font-size:.75rem;padding:6px 2px;min-height:36px}.weekday-long{display:none}.weekday-short{display:inline}.month-calendar-event{padding:3px 4px;border-radius:6px;gap:0}.month-calendar-event span{font-size:.62rem}.month-calendar-event small{display:none}.month-calendar-events{gap:3px;margin-top:3px}.month-calendar-day-today{width:1.4rem;height:1.4rem;font-size:.88rem}}.dashboard-calendar-card-compact{padding:16px}.weekday-short{display:none}.weekday-long{display:inline}.month-calendar-weekday{display:grid;place-items:center;min-height:56px;padding:10px;border-right:1px solid rgba(16,35,58,.22);border-bottom:1px solid rgba(16,35,58,.22);font-size:.86rem;font-weight:800;text-align:center}.month-calendar-weekday:nth-child(7n){border-right:0}.month-calendar-cell{min-height:146px;padding:10px;border-right:1px solid rgba(16,35,58,.22);border-bottom:1px solid rgba(16,35,58,.22);background:white;overflow:hidden;min-width:0}.month-calendar-cell:nth-child(7n){border-right:0}.month-calendar-cell-muted{background:rgba(239,244,248,.7)}.month-calendar-day-number{font-size:1.35rem;font-weight:800}.month-calendar-cell-today{background:rgba(232,98,10,.04)}.month-calendar-day-today{display:inline-flex;align-items:center;justify-content:center;width:2rem;height:2rem;border-radius:50%;background:#e8620a;color:#fff;line-height:1}.month-calendar-grid-compact .month-calendar-day-today{width:1.6rem;height:1.6rem;font-size:1rem}.month-calendar-events{display:grid;grid-gap:6px;gap:6px;margin-top:6px;min-width:0}.month-calendar-event{display:grid;grid-gap:2px;gap:2px;width:100%;min-width:0;padding:8px 10px;border-radius:12px;border:0;text-align:left;cursor:pointer;font:inherit}.month-calendar-event-card{display:grid;grid-gap:5px;gap:5px;min-width:0}.month-calendar-event-card-active{padding:2px;border-radius:14px;outline:2px solid rgba(15,76,129,.34)}.month-calendar-event span{font-size:.88rem;font-weight:700;line-height:1.15}.month-calendar-event small,.month-calendar-event span{overflow:hidden;white-space:nowrap;text-overflow:ellipsis}.month-calendar-event small{font-size:.7rem;opacity:.9}.month-calendar-event-actions{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));grid-gap:4px;gap:4px}.month-calendar-action{min-height:30px;padding:0 6px;border-radius:10px;font-size:.72rem}.calendar-page-layout{grid-template-columns:minmax(0,1fr) 320px;align-items:start}.calendar-main-stack,.calendar-page-layout,.calendar-sidebar{display:grid;grid-gap:16px;gap:16px}.calendar-sidebar{align-content:start}.analytics-card{background:rgba(255,255,255,.92);border:1px solid rgba(16,35,58,.08);border-radius:24px;padding:20px;box-shadow:var(--shadow);display:grid;grid-gap:16px;gap:16px}.analytics-header h3{margin:4px 0 0;font-size:1.1rem;font-weight:700;color:var(--ink)}.analytics-stats{display:grid;grid-template-columns:1fr 1fr;grid-gap:10px;gap:10px}.analytics-stat{background:rgba(15,76,129,.06);border-radius:14px;padding:12px 14px;display:grid;grid-gap:2px;gap:2px}.analytics-stat strong{font-size:2rem;font-weight:800;line-height:1;color:var(--ink)}.analytics-stat span{font-size:.76rem;color:var(--muted)}.analytics-donut-wrap{display:flex;justify-content:center}.analytics-donut{width:180px;height:180px;overflow:visible}.analytics-donut-num{font-size:26px;font-weight:800;fill:var(--ink)}.analytics-donut-label{font-size:11px;fill:var(--muted)}.analytics-legend{display:grid;grid-gap:8px;gap:8px}.analytics-legend-row{display:grid;grid-template-columns:10px 1fr auto auto;align-items:center;grid-gap:8px;gap:8px;font-size:.82rem}.analytics-legend-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0}.analytics-legend-name{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;color:var(--ink)}.analytics-legend-pct{font-weight:700;color:var(--ink)}.analytics-legend-count{color:var(--muted)}.analytics-empty{padding:8px 0 4px;text-align:center}.analytics-empty p{margin:0;color:var(--muted);font-size:.88rem;line-height:1.5}.analytics-empty-sub{margin-top:6px!important;font-size:.76rem!important;opacity:.8}.analytics-view-toggle{display:grid;grid-template-columns:1fr 1fr;grid-gap:6px;gap:6px;padding:4px;border-radius:14px;background:rgba(16,35,58,.06)}.analytics-toggle-btn{min-height:36px;border-radius:10px;border:none;background:transparent;color:var(--muted);font:inherit;font-size:.88rem;font-weight:700;cursor:pointer;transition:background .14s ease,color .14s ease}.analytics-toggle-active{background:white;color:var(--primary-strong);box-shadow:0 1px 4px rgba(16,35,58,.12)}.analytics-range{display:grid;grid-gap:8px;gap:8px}.analytics-range-row{display:grid;grid-template-columns:56px 1fr;align-items:center;grid-gap:8px;gap:8px}.analytics-range-label{font-size:.8rem;font-weight:700;color:var(--muted)}.analytics-range-input{min-height:36px;padding:6px 10px;font-size:.84rem}.analytics-reset-btn{background:none;border:none;color:var(--primary);font:inherit;font-size:.82rem;font-weight:700;cursor:pointer;padding:2px 0;text-align:left}.week-calendar-card{display:grid;grid-gap:16px;gap:16px;padding:20px;border-radius:24px;border:1px solid rgba(16,35,58,.08);background:rgba(255,255,255,.92);box-shadow:var(--shadow)}.week-calendar-header{display:flex;align-items:flex-end;justify-content:space-between;gap:16px}.week-calendar-header h2{margin:6px 0 0;font-size:2rem}.week-calendar-grid{display:grid;grid-template-columns:repeat(7,minmax(0,1fr));grid-gap:10px;gap:10px}.week-calendar-day{display:grid;grid-gap:12px;gap:12px;min-width:0;min-height:260px;padding:12px;border-radius:18px;border:1px solid rgba(16,35,58,.08);background:rgba(255,255,255,.88)}.week-calendar-day-header{display:grid;grid-gap:4px;gap:4px}.week-calendar-day-header h3{margin:0}.week-calendar-day-header span{color:var(--muted);font-size:.88rem}.week-calendar-events{align-content:start}.week-calendar-event,.week-calendar-events{display:grid;grid-gap:10px;gap:10px;min-width:0}.week-calendar-event{max-width:100%;overflow:hidden;padding:10px;border-radius:14px}.week-calendar-event-active{box-shadow:inset 0 0 0 2px rgba(15,76,129,.28)}.week-calendar-event-practice{background:rgba(21,127,91,.12)}.week-calendar-event-game{background:rgba(214,40,57,.12)}.week-calendar-event-meeting{background:rgba(15,76,129,.12)}.week-calendar-event-main{display:grid;grid-gap:4px;gap:4px;min-width:0;max-width:100%;border:0;background:transparent;padding:0;text-align:left;cursor:pointer;font:inherit}.week-calendar-event-main small,.week-calendar-event-main span,.week-calendar-event-main strong{min-width:0;max-width:100%;overflow:hidden;overflow-wrap:anywhere;word-break:break-word;-webkit-hyphens:auto;hyphens:auto;line-height:1.18}.week-calendar-event-main strong{font-size:.92rem}.week-calendar-event-main small,.week-calendar-event-main span{color:var(--muted)}.week-calendar-event-editor{display:grid;grid-gap:8px;gap:8px}.week-calendar-event-input,.week-calendar-event-time{min-height:38px;padding:8px 10px;font-size:.86rem}.week-calendar-event-actions{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));grid-gap:8px;gap:8px}.week-calendar-remove{min-height:38px;padding:0 12px}.month-calendar-event-practice{background:rgba(21,127,91,.12);color:var(--success)}.month-calendar-event-game{background:rgba(214,40,57,.12);color:var(--accent)}.month-calendar-event-meeting{background:rgba(15,76,129,.12);color:var(--primary-strong)}.dashboard-info-card h3{margin:0 0 12px}.dashboard-stats-strip{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));grid-gap:12px;gap:12px;margin-bottom:18px}.dashboard-stat{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;padding:16px 12px;border-radius:18px;background:rgba(255,255,255,.88);border:1px solid rgba(16,35,58,.08);box-shadow:0 2px 8px rgba(16,35,58,.06);text-align:center}.dashboard-stat-value{font-size:clamp(1.6rem,3vw,2.2rem);font-weight:900;color:var(--primary-strong);line-height:1}.dashboard-stat-label{font-size:.72rem;font-weight:600;color:var(--muted);text-transform:uppercase;letter-spacing:.06em}@media (max-width:640px){.dashboard-stats-strip{grid-template-columns:repeat(2,minmax(0,1fr))}}.dashboard-upcoming-list{display:grid;grid-gap:8px;gap:8px}.dashboard-upcoming-item{display:flex;align-items:center;gap:10px;width:100%;padding:10px 12px;border-radius:14px;border:1px solid rgba(16,35,58,.08);background:rgba(255,255,255,.82);cursor:pointer;font:inherit;text-align:left;transition:background .14s ease,transform .14s ease}.dashboard-upcoming-item:hover{background:rgba(15,76,129,.06);transform:translateY(-1px)}.dashboard-upcoming-badge{flex-shrink:0;display:inline-flex;align-items:center;min-height:22px;padding:0 7px;border-radius:999px;font-size:.68rem;font-weight:800;letter-spacing:.04em;text-transform:uppercase}.dashboard-upcoming-badge-practice{background:rgba(21,127,91,.12);color:var(--success)}.dashboard-upcoming-badge-game{background:rgba(214,40,57,.12);color:var(--accent)}.dashboard-upcoming-badge-meeting{background:rgba(15,76,129,.12);color:var(--primary)}.dashboard-upcoming-copy{display:grid;grid-gap:1px;gap:1px;min-width:0}.dashboard-upcoming-copy strong{font-size:.88rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.dashboard-upcoming-copy span{font-size:.76rem;color:var(--muted)}.dashboard-upcoming-empty{margin:0;font-size:.88rem;color:var(--muted)}.dashboard-upcoming-link{color:var(--primary);font-weight:700;text-decoration:underline;text-underline-offset:2px}.dashboard-info-list,.dashboard-plan-list{display:grid;grid-gap:10px;gap:10px}.dashboard-info-row{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:12px 14px;border-radius:16px;background:rgba(15,76,129,.06)}.dashboard-info-row span{color:var(--muted);font-size:.9rem}.dashboard-plan-button{display:grid;grid-gap:4px;gap:4px;width:100%;padding:14px;border-radius:16px;border:1px solid rgba(16,35,58,.08);background:rgba(255,255,255,.82);text-align:left;cursor:pointer;font:inherit}.dashboard-plan-button span{color:var(--muted);font-size:.85rem}.library-layout{grid-template-columns:290px minmax(0,1fr);grid-template-rows:auto auto}.library-layout,.library-sidebar{display:grid;grid-gap:16px;gap:16px}.library-sidebar{align-self:start;position:-webkit-sticky;position:sticky;top:16px;grid-column:1;grid-row:1}.library-main{grid-column:2;grid-row:1/3}.library-plans-panel{grid-column:1;grid-row:2;align-self:start}.sidebar-field-list{max-height:260px;overflow-y:auto;scrollbar-width:thin}.category-card-inner{display:flex;flex-direction:column;gap:0}.category-scroll-list{display:flex;flex-direction:column;gap:6px;max-height:240px;overflow-y:auto;scrollbar-width:thin;padding-bottom:4px}.category-row{display:flex;align-items:center;gap:4px}.category-row-folder-btn{flex:1 1;min-width:0}.category-row-actions{display:flex;gap:2px;flex-shrink:0;opacity:0;transition:opacity .12s}.category-row:focus-within .category-row-actions,.category-row:hover .category-row-actions{opacity:1}.category-action-btn{display:flex;align-items:center;justify-content:center;width:28px;height:28px;border-radius:8px;border:none;background:transparent;color:var(--muted,#8a9bb0);cursor:pointer;padding:0;transition:background .12s,color .12s}.category-action-btn:hover{background:rgba(15,76,129,.1);color:var(--primary-strong)}.category-action-btn-delete:hover{background:rgba(220,38,38,.1);color:#dc2626}.category-rename-row{display:flex;align-items:center;gap:4px;width:100%}.category-rename-row .category-rename-input{flex:1 1;min-width:0}.category-rename-input{width:100%;min-height:40px;font-weight:700;font-size:.95rem}.category-action-btn-save{flex-shrink:0;width:36px;height:36px;background:rgba(22,163,74,.12);color:#16a34a}.category-action-btn-save:hover{background:rgba(22,163,74,.2);color:#15803d}.category-new-form{display:flex;flex-direction:column;gap:8px;padding-top:12px;margin-top:8px;border-top:1px solid var(--border,#e2e8f0)}.library-main{display:grid;grid-gap:16px;gap:16px;align-content:start;min-height:0}.library-drill-scroll{overflow-y:auto;max-height:calc(100vh - 240px);padding-right:4px;scrollbar-width:thin;scrollbar-color:rgba(15,76,129,.3) transparent}.library-drill-scroll::-webkit-scrollbar{width:5px}.library-drill-scroll::-webkit-scrollbar-track{background:transparent}.library-drill-scroll::-webkit-scrollbar-thumb{background:rgba(15,76,129,.3);border-radius:3px}.library-toolbar{display:flex;align-items:flex-end;justify-content:space-between;gap:16px}.library-toolbar h2{margin:6px 0 0;font-size:1.55rem}.library-empty-state{display:grid;align-content:start;justify-items:start;grid-gap:10px;gap:10px;min-height:220px;padding:22px;border-radius:24px;border:1px dashed rgba(16,35,58,.22);background:rgba(255,255,255,.74)}.library-empty-state h3,.library-empty-state p{margin:0}.library-empty-state p{color:var(--muted)}.drill-card-rink{margin:4px -4px 12px;height:140px;overflow:hidden}.drill-card-rink,.drill-card-rink .rink-wrap{display:flex;align-items:center;justify-content:center}.drill-card-rink .rink-wrap{gap:0;width:100%;height:100%}.drill-card-rink .rink-svg{display:block;max-width:100%;max-height:100%;width:auto;height:auto;border-radius:0;background:transparent;overflow:hidden}.drill-card-description{min-height:2.8em;line-height:1.35}.drill-preview-modal{position:fixed;inset:0;z-index:100;display:grid;place-items:center;padding:24px}.drill-preview-backdrop{position:absolute;inset:0;border:0;background:rgba(8,22,39,.58);cursor:pointer}.drill-preview-dialog{position:relative;z-index:1;display:grid;grid-gap:16px;gap:16px;width:min(1120px,calc(100vw - 48px));max-height:calc(100vh - 48px);overflow:auto;padding:22px;border-radius:28px;border:1px solid rgba(255,255,255,.62);background:rgba(255,255,255,.96);box-shadow:0 30px 80px rgba(8,22,39,.32)}.drill-preview-header{display:flex;align-items:flex-start;justify-content:space-between;gap:16px}.drill-preview-header h2{margin:5px 0 4px;font-size:clamp(1.6rem,3vw,2.6rem)}.drill-preview-description,.drill-preview-header p{margin:0;color:var(--muted)}.drill-preview-rink .rink-card{min-height:460px}.meeting-dialog{width:min(680px,calc(100vw - 48px))}.meeting-notes-textarea{min-height:220px;line-height:1.45}.drill-phase-preview-list{display:grid;grid-gap:18px;gap:18px}.drill-phase-preview-item{display:grid;grid-gap:10px;gap:10px}.drill-phase-preview-item h3{margin:0;font-size:1.1rem}.folder-button{display:flex;align-items:center;justify-content:space-between;gap:10px;width:100%;min-height:46px;padding:0 14px;border-radius:14px;border:1px solid rgba(16,35,58,.08);background:rgba(255,255,255,.82);color:var(--ink);cursor:pointer;font:inherit;font-weight:700;text-align:left}.folder-button-active{background:rgba(15,76,129,.12);border-color:rgba(15,76,129,.24);color:var(--primary-strong)}.practice-folder-button{display:grid;justify-content:start;grid-gap:4px;gap:4px;min-height:62px;padding:12px 14px}.practice-folder-button span{color:var(--muted);font-size:.82rem}.practice-category-tabs{display:flex;flex-wrap:wrap;gap:10px;margin-bottom:14px}.practice-category-tab{width:auto;min-width:140px}.practice-category-stacks{display:grid;grid-gap:14px;gap:14px}.practice-category-stack{display:grid;grid-gap:10px;gap:10px;padding:14px;border-radius:18px;background:rgba(15,76,129,.05);border:1px solid rgba(16,35,58,.08)}.practice-category-stack-title{font-size:1rem;font-weight:800}.practice-drill-list{display:grid;grid-gap:10px;gap:10px}.practice-drill-card-wide{min-height:92px}.practice-plan-item{display:grid;grid-template-columns:minmax(0,1fr) 108px auto;align-items:center}.practice-drill-card-copy{min-width:0}.practice-drill-thumb-button{display:block;width:108px;padding:0;border:1px solid rgba(16,35,58,.12);border-radius:12px;background:white;cursor:pointer;overflow:hidden}.practice-drill-thumb-button .rink-card{min-height:58px;padding:2px;border:0;border-radius:0;box-shadow:none}.practice-drill-thumb-button .rink-label{display:none}.practice-add-btn{display:flex;align-items:center;justify-content:center;width:44px;height:44px;border-radius:50%;border:none;background:#16a34a;color:#fff;cursor:pointer;flex-shrink:0;align-self:center;transition:background .15s,transform .1s}.practice-add-btn:hover{background:#15803d;transform:scale(1.08)}.practice-add-btn:active{transform:scale(.95)}.plan-item-arrow-btn{display:flex;align-items:center;justify-content:center;width:34px;height:34px;border-radius:8px;border:1px solid rgba(16,35,58,.14);background:rgba(255,255,255,.8);color:var(--primary-strong);cursor:pointer;transition:background .12s;flex-shrink:0}.plan-item-arrow-btn:hover{background:rgba(15,76,129,.1)}.practice-history-list,.practice-history-preview-list{display:grid;grid-gap:10px;gap:10px}.practice-history-item{display:flex;flex-wrap:wrap;align-items:center;gap:8px;padding:12px;border-radius:16px;border:1px solid rgba(16,35,58,.08);background:rgba(255,255,255,.78)}.practice-history-item .practice-history-main{flex:1 1;min-width:160px}.practice-history-main{display:grid;grid-gap:4px;gap:4px;padding:0;border:0;background:transparent;text-align:left;cursor:pointer;font:inherit}.practice-history-main span,.practice-history-preview-item span{color:var(--muted);font-size:.88rem}.practice-history-preview-item{display:grid;grid-template-columns:minmax(180px,.7fr) minmax(260px,1fr);grid-gap:14px;gap:14px;align-items:center;padding:14px;border-radius:18px;background:rgba(15,76,129,.05)}.practice-history-preview-item .rink-card{min-height:180px}.settings-header{margin-bottom:16px}.settings-layout{display:grid;grid-gap:20px;gap:20px;max-width:720px}.panel-rink{padding:22px}.editor-pro-layout{display:grid;grid-template-columns:minmax(0,1fr) 258px;grid-gap:8px;gap:8px;align-items:stretch}.editor-stage-card{display:grid;grid-gap:5px;gap:5px;padding:6px;border-radius:28px;border:1px solid rgba(16,35,58,.08);background:rgba(255,255,255,.92);min-width:0;overflow:hidden;box-shadow:var(--shadow)}.editor-pro-topbar{display:flex;align-items:flex-start;justify-content:space-between;gap:16px}.editor-pro-topbar h2{margin:6px 0 0;font-size:clamp(1.2rem,1.8vw,1.6rem)}.editor-topbar-actions{display:flex;flex-wrap:wrap;gap:10px}.editor-preset-strip{display:flex;align-items:stretch;gap:6px;overflow-x:visible;padding-bottom:2px;flex-wrap:nowrap}.editor-phase-strip{display:grid;grid-gap:8px;gap:8px;padding:8px;border-radius:18px;background:rgba(15,76,129,.05);border:1px solid rgba(16,35,58,.08)}.editor-phase-actions,.editor-phase-tabs{display:flex;align-items:center;flex-wrap:wrap;gap:8px}.editor-phase-tab{display:grid;grid-gap:1px;gap:1px;min-width:92px;padding:7px 10px;border-radius:13px;border:1px solid rgba(16,35,58,.1);background:rgba(255,255,255,.86);color:var(--ink);cursor:pointer;font:inherit;text-align:left}.editor-phase-tab span{font-size:.86rem;font-weight:800}.editor-phase-tab small{color:var(--muted);font-size:.66rem}.editor-phase-tab-active{background:rgba(15,76,129,.13);border-color:rgba(15,76,129,.3);color:var(--primary-strong)}.editor-phase-title-input{width:180px;min-height:34px;padding:0 10px;border-radius:12px;font-size:.84rem}.rink-preset-card{display:grid;grid-gap:4px;gap:4px;min-width:76px;padding:5px;border:1px solid rgba(16,35,58,.1);border-radius:16px;background:rgba(255,255,255,.86);cursor:pointer}.rink-preset-card span{font-size:.62rem;font-weight:700}.rink-preset-card-active{border-color:rgba(15,76,129,.34);background:rgba(15,76,129,.1)}.rink-preset-preview{width:100%;height:34px}.editor-orientation-controls{display:flex;gap:8px;margin-left:auto}.editor-mini-button{min-height:30px;padding:0 8px;border-radius:12px;font-size:.72rem}.editor-mini-button-active{background:rgba(15,76,129,.12);border-color:rgba(15,76,129,.26)}.editor-surface-shell{display:grid;grid-gap:6px;gap:6px}.editor-surface-meta{display:flex;align-items:center;justify-content:flex-end;gap:6px}.editor-surface-actions{display:flex;gap:10px}.rink-editor-frame{padding:5px 6px 4px;border-radius:22px;background:linear-gradient(180deg,rgba(255,255,255,.98),rgba(239,244,248,.96));border:1px solid rgba(16,35,58,.08)}.rink-editor-frame-portrait{display:grid;place-items:center}.editor-toolbar-bottom{display:flex;align-items:center;flex-wrap:nowrap;gap:6px;min-height:50px;padding:5px 8px 4px;overflow:visible;justify-content:center;width:100%;min-width:0}.editor-save-notice{display:inline-flex;align-items:center;min-height:40px;padding:0 14px;border-radius:999px;background:rgba(16,185,129,.12);color:#047857;font-size:.88rem;font-weight:800;white-space:nowrap}.editor-manual-btn{font-size:.82rem;padding:0 12px;height:34px;opacity:.75}.editor-manual-btn:hover{opacity:1}.editor-manual-backdrop{position:fixed;inset:0;z-index:9000;background:rgba(0,0,0,.55);display:flex;align-items:center;justify-content:center;padding:20px;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.editor-manual-modal{background:#1a2636;border:1px solid rgba(255,255,255,.1);border-radius:14px;width:100%;max-width:620px;max-height:85vh;display:flex;flex-direction:column;box-shadow:0 24px 60px rgba(0,0,0,.5);overflow:hidden}.editor-manual-header{display:flex;align-items:center;justify-content:space-between;padding:20px 24px 16px;border-bottom:1px solid rgba(255,255,255,.08);flex-shrink:0}.editor-manual-title{font-size:1.1rem;font-weight:700;color:#f0f4f8;margin:0}.editor-manual-close{background:none;border:none;color:rgba(255,255,255,.45);font-size:1.1rem;cursor:pointer;padding:4px 8px;border-radius:6px;line-height:1;transition:color .15s,background .15s}.editor-manual-close:hover{color:#f0f4f8;background:rgba(255,255,255,.08)}.editor-manual-body{overflow-y:auto;padding:20px 24px 28px;display:flex;flex-direction:column;gap:24px;scrollbar-width:thin;scrollbar-color:rgba(255,255,255,.15) transparent}.editor-manual-section h3{font-size:.82rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:#e8620a;margin:0 0 10px}.editor-manual-section p,.editor-manual-section ul{font-size:.9rem;color:rgba(240,244,248,.8);line-height:1.65;margin:0 0 8px}.editor-manual-section p:last-child,.editor-manual-section ul:last-child{margin-bottom:0}.editor-manual-section ul{padding-left:18px}.editor-manual-section ul li{margin-bottom:4px}.editor-manual-section code{background:rgba(232,98,10,.15);color:#e8a87c;padding:1px 6px;border-radius:4px;font-size:.85rem}.editor-manual-note{font-size:.82rem!important;color:rgba(240,244,248,.45)!important;font-style:italic;margin-top:6px!important}.editor-manual-shortcuts{display:flex;flex-direction:column;gap:6px;margin:10px 0}.editor-manual-shortcut-row{display:flex;align-items:center;gap:8px;font-size:.88rem;color:rgba(240,244,248,.8)}kbd{display:inline-flex;align-items:center;justify-content:center;min-width:28px;padding:2px 7px;background:rgba(255,255,255,.07);border:solid rgba(255,255,255,.15);border-width:1px 1px 2px;border-radius:5px;font-family:inherit;font-size:.78rem;font-weight:700;color:#f0f4f8;white-space:nowrap;flex-shrink:0}.editor-toolbar-group{position:relative;flex:0 0 auto}.editor-tool-chip{display:inline-flex;align-items:center;justify-content:center;min-height:40px;min-width:40px;width:40px;padding:0;border-radius:4px;border:1px solid transparent;background:transparent;color:var(--ink);cursor:pointer;font:inherit;font-size:.78rem;font-weight:600;white-space:nowrap;flex:0 0 auto;box-shadow:none;transition:background .14s ease,color .14s ease,transform .14s ease}.editor-toolbar-icon{width:29px;height:29px;display:block;color:currentColor}.editor-tool-chip:hover:not(:disabled){background:rgba(16,35,58,.06)}.editor-tool-chip:disabled{cursor:not-allowed;opacity:.32}.editor-tool-chip-active{background:rgba(16,35,58,.1);border-color:transparent;color:var(--ink)}.editor-tool-chip-danger{color:var(--accent)}.editor-toolbar-flyout{position:absolute;left:0;bottom:calc(100% + 2px);z-index:30;display:grid;grid-gap:3px;gap:3px;min-width:236px;padding:8px;border-radius:8px;border:1px solid rgba(16,35,58,.1);background:rgba(255,255,255,.98);box-shadow:0 16px 34px rgba(16,35,58,.16)}.editor-toolbar-flyout-item{display:grid;grid-template-columns:34px minmax(0,1fr);align-items:center;grid-column-gap:8px;column-gap:8px;grid-row-gap:1px;row-gap:1px;padding:9px 10px;border:0;border-radius:6px;background:transparent;cursor:pointer;font:inherit;text-align:left}.editor-toolbar-flyout-item:hover{background:rgba(16,35,58,.06)}.editor-toolbar-flyout-icon{grid-row:1/span 2;display:grid;place-items:center}.editor-toolbar-flyout-icon .editor-toolbar-icon{width:28px;height:28px}.editor-toolbar-flyout-item span{font-size:.9rem;font-weight:600}.editor-toolbar-flyout-item small{color:var(--muted);font-size:.74rem}.editor-toolbar-flyout-item-active{background:rgba(16,35,58,.1)}.editor-color-row{display:flex;align-items:center;flex-wrap:wrap;gap:7px;padding:2px;justify-content:center;flex:0 0 auto}.editor-color-row-flyout{width:158px}.editor-toolbar-flyout-colors{min-width:162px}.editor-color-swatch{width:24px;height:24px;border-radius:999px;border:2px solid rgba(255,255,255,.92);box-shadow:0 0 0 1px rgba(16,35,58,.18);cursor:pointer;flex:0 0 auto}.editor-color-swatch-active{box-shadow:0 0 0 2px rgba(16,35,58,.45)}.editor-color-swatch-small{width:16px;height:16px;border-radius:999px;border:1.5px solid rgba(255,255,255,.9);box-shadow:0 0 0 1px rgba(16,35,58,.22);flex-shrink:0;cursor:pointer;display:inline-block}.editor-color-defaults{margin-top:6px;padding-top:6px;border-top:1px solid rgba(16,35,58,.12);width:100%}.editor-color-defaults-header{font-size:10px;font-weight:700;letter-spacing:.04em;text-transform:uppercase;color:rgba(16,35,58,.55);margin-bottom:5px}.editor-color-default-save-row{display:flex;align-items:center;gap:6px;margin-bottom:4px}.editor-color-default-name{font-size:11px;font-weight:600;color:rgba(16,35,58,.8);flex:1 1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.editor-color-defaults-list{display:flex;flex-direction:column;gap:3px;max-height:140px;overflow-y:auto}.editor-color-default-row{display:flex;align-items:center;gap:6px}.editor-color-default-clear{background:none;border:none;cursor:pointer;color:rgba(16,35,58,.4);font-size:10px;padding:0 2px;line-height:1;flex-shrink:0}.editor-color-default-clear:hover{color:#d62839}.editor-pro-sidebar{display:flex;flex-direction:column;gap:10px;position:-webkit-sticky;position:sticky;top:92px;align-self:stretch;overflow-y:auto}.editor-pro-sidebar .editor-panel{position:static;flex:1 1;min-height:0;overflow-y:auto}.editor-rotate-panel{flex:0 0 auto;padding:12px 16px}.editor-rotate-row{display:flex;gap:8px;align-items:center}.editor-rotate-btn{display:flex;align-items:center;gap:5px;font-size:.82rem;padding:6px 10px;min-height:32px}@page{size:A4;margin:7mm}.video-field-row{display:flex;gap:8px;align-items:stretch}.video-field-row .input{flex:1 1;min-width:0}.video-browse-btn{white-space:nowrap;flex-shrink:0}.video-field-col{display:flex;flex-direction:column;gap:8px}.video-url-input{width:100%;background:var(--surface);cursor:default}.video-btn-row{gap:8px;flex-wrap:wrap}.video-btn-row,.video-icon-btn{display:flex;align-items:center}.video-icon-btn{gap:5px;font-size:.8rem;padding:5px 10px}.editor-tag-section-wrapper{position:relative;margin-top:8px}.editor-tag-manager-popup{position:absolute;bottom:calc(100% + 4px);left:0;right:0;z-index:50;box-shadow:0 -4px 24px rgba(15,76,129,.14),0 2px 8px rgba(0,0,0,.08);border:1px solid rgba(15,76,129,.18);border-radius:16px;background:var(--surface);max-height:60vh;overflow-y:auto}.editor-tag-section-header{margin-bottom:0}.editor-tag-toggle-btn{width:100%;display:flex;align-items:center;justify-content:center;gap:7px;padding:8px 14px;font-size:.85rem;font-weight:600;border-radius:10px;border:1.5px dashed rgba(15,76,129,.35);background:rgba(15,76,129,.04);color:var(--primary);cursor:pointer;transition:background .15s,border-color .15s}.editor-tag-toggle-btn:hover{background:rgba(15,76,129,.09);border-color:rgba(15,76,129,.5)}.editor-tag-toggle-btn-active{background:rgba(15,76,129,.1);border-color:var(--primary);border-style:solid}.editor-tag-manager-header{display:flex;align-items:center;justify-content:space-between;gap:8px}.editor-tag-manager-header strong{font-size:.85rem;color:var(--ink)}.editor-tag-manager-close{width:24px;height:24px;border-radius:50%;border:none;background:rgba(16,35,58,.08);color:var(--muted);font-size:.85rem;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .15s,color .15s;flex-shrink:0}.editor-tag-manager-close:hover{background:rgba(214,40,57,.1);color:var(--accent)}.video-link-modal-backdrop{position:fixed;inset:0;background:rgba(10,18,30,.55);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:9000;display:flex;align-items:center;justify-content:center}.video-link-modal{background:var(--surface-strong);border:1px solid var(--line);border-radius:16px;box-shadow:0 24px 64px rgba(10,18,30,.4);padding:28px 28px 24px;width:min(440px,calc(100vw - 32px));display:flex;flex-direction:column;gap:14px}.video-link-modal-title{font-size:1.1rem;font-weight:700;margin:0;color:var(--ink)}.video-link-modal-hint{font-size:.85rem;color:var(--muted);margin:-6px 0 0}.video-link-modal-actions{display:flex;gap:10px;justify-content:flex-end;margin-top:4px}.video-field-meta{display:flex;align-items:center;justify-content:space-between;gap:8px;margin-top:6px;font-size:.82rem;color:var(--muted)}.video-field-clear{background:none;border:none;padding:0;font-size:.82rem;color:var(--accent);cursor:pointer;white-space:nowrap}.video-field-clear:hover{text-decoration:underline}.card-header{display:flex;align-items:flex-start;justify-content:space-between}.card-header-action{flex-shrink:0;margin-left:8px}.card-video-btn{display:flex;align-items:center;justify-content:center;width:32px;height:32px;border:none;border-radius:8px;background:transparent;color:var(--primary);cursor:pointer;transition:background .15s,color .15s}.card-video-btn:hover{background:rgba(15,76,129,.1);color:var(--primary-strong)}.video-modal-backdrop{position:fixed;inset:0;z-index:200;background:rgba(0,0,0,.92);display:flex;align-items:center;justify-content:center;padding:24px}.video-modal-container{position:relative;width:100%;max-width:900px;aspect-ratio:16/9;background:#000;border-radius:8px;overflow:hidden;box-shadow:0 32px 80px rgba(0,0,0,.8)}.video-modal-close{position:absolute;top:12px;right:14px;z-index:10;width:36px;height:36px;border:none;border-radius:50%;background:rgba(255,255,255,.15);color:#fff;font-size:1rem;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .15s}.video-modal-close:hover{background:rgba(255,255,255,.28)}.video-modal-frame{width:100%;height:100%;border:none;display:block}.video-modal-url-fallback{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:16px;height:100%;color:rgba(255,255,255,.7);text-align:center}.video-modal-url-fallback p{margin:0;font-size:.95rem}.faceoff-card-body .card-video-btn{margin-left:auto}@media print{body{background:#ffffff}.no-print,body.printing-faceoff .app-shell,body.printing-faceoff .auth-loading,body.printing-faceoff .drill-preview-backdrop,body.printing-faceoff .drill-preview-header,body.printing-faceoff .faceoff-library-grid,body.printing-faceoff .faceoff-page-controls,body.printing-faceoff footer,body.printing-faceoff nav{display:none!important}body.printing-faceoff .drill-preview-modal{position:static!important;inset:auto!important;background:transparent!important;display:block!important}body.printing-faceoff .drill-preview-dialog{box-shadow:none!important;border:none!important;width:100%!important;max-width:100%!important;margin:0!important;border-radius:0!important}body.printing-faceoff .faceoff-card-preview-large{max-width:100%!important;padding:0!important}body.printing-faceoff .faceoff-card-preview-large svg{width:100%!important;height:auto!important}.print-page{padding:0;background:#ffffff}.print-toolbar{display:none}.print-sheet{width:100%;padding:0;border-radius:0;box-shadow:none}.print-header{padding-bottom:6px}.print-block{margin-top:8px}.print-timeline-item{padding:5px 8px}.print-drill-card{grid-template-columns:.52fr 1.48fr;gap:7px;padding:7px 8px}.print-drill-phase .rink-svg{max-height:132px}.print-drill-phase .rink-svg-portrait{width:auto;max-height:132px;display:block;margin:0 auto}.print-drill-list{gap:6px}}@media (max-width:1400px){.editor-layout{grid-template-columns:196px minmax(0,1fr) 272px;gap:10px}.editor-layout-wide{grid-template-columns:180px minmax(0,1.65fr) 244px;gap:8px}.editor-pro-layout{grid-template-columns:minmax(0,1fr) 220px}.editor-pro-sidebar{width:220px}.editor-toolbar-bottom{flex-wrap:wrap;justify-content:center}}@media (max-width:1200px){.library-layout{grid-template-columns:240px minmax(0,1fr)}.calendar-page-layout{grid-template-columns:minmax(0,1fr) 280px}.calendar-sidebar{width:280px}}@media (max-width:960px){.calendar-grid,.dashboard-layout,.editor-layout,.grid.cols-2,.grid.cols-3,.layout-split,.layout-split-equal,.library-layout,.stats{grid-template-columns:1fr;grid-template-rows:auto;display:flex;flex-direction:column}.library-sidebar{position:static;order:1}.library-main{order:2}.library-plans-panel{order:3}.calendar-page-layout,.editor-pro-layout,.library-layout,.week-calendar-grid{grid-template-columns:1fr}.editor-pro-sidebar{position:static;width:auto}.calendar-sidebar{width:auto}.editor-pro-topbar,.editor-surface-meta,.hero,.library-toolbar,.month-calendar-header,.nav,.week-calendar-header{align-items:start;flex-direction:column}.rink-svg-editor{min-height:320px}.rink-svg-editor-portrait{min-height:360px;max-height:none}.rink-svg-editor-half-portrait{width:min(100%,420px);height:auto;max-height:none;min-height:0}.rink-svg-editor-half-landscape{width:min(100%,400px)}.editor-details-header{align-items:start;flex-direction:column}.editor-details-actions{justify-content:flex-start}.editor-shortcut-row{grid-template-columns:minmax(0,1fr) 52px}.editor-shortcut-row .editor-mini-button{grid-column:1/-1}.editor-orientation-controls{margin-left:0}}.page-main-faceoffs{width:min(1400px,calc(100% - 8px))}.page-content{flex:1 1}.app-footer{border-top:1px solid var(--border,#e2e8f0);padding:16px 24px;margin-top:auto}.footer-inner{max-width:1200px;margin:0 auto;align-items:center;justify-content:space-between;font-size:.78rem;color:var(--muted)}.footer-inner,.footer-links{display:flex;gap:16px}.footer-link{color:var(--muted);text-decoration:underline;text-underline-offset:2px}.footer-link:hover{color:var(--ink)}.onboarding-banner{display:flex;align-items:center;justify-content:space-between;gap:16px;background:#fff8ed;border:1px solid #f0c070;border-radius:10px;padding:12px 18px;margin-bottom:20px;font-size:.92rem;color:#7a5000}.onboarding-banner-link{font-weight:700;color:#e8620a;white-space:nowrap;text-decoration:underline;text-underline-offset:2px}.legal-page{min-height:100vh;display:flex;flex-direction:column;background:var(--surface,#f8fafc)}.legal-header{padding:20px 32px;border-bottom:1px solid var(--border,#e2e8f0);background:white;justify-content:space-between}.legal-header,.legal-logo-link{display:flex;align-items:center}.legal-logo-link{gap:10px;text-decoration:none;color:var(--ink);font-size:1rem}.legal-content{max-width:760px;margin:0 auto;padding:40px 24px 60px;flex:1 1}.legal-content h1{font-size:2rem;font-weight:900;margin-bottom:4px}.legal-updated{color:var(--muted);font-size:.85rem;margin-bottom:32px}.legal-content h2{font-size:1.05rem;font-weight:700;margin-top:28px;margin-bottom:8px;color:var(--ink)}.legal-content li,.legal-content p{font-size:.92rem;line-height:1.7;color:var(--muted)}.legal-content ul{padding-left:20px;margin:8px 0}.legal-content a{color:var(--primary);text-decoration:underline}.legal-footer{padding:20px 32px;border-top:1px solid var(--border,#e2e8f0);display:flex;gap:24px;font-size:.85rem}.legal-footer a{color:var(--muted);text-decoration:underline}.faceoff-library-empty{padding:48px 24px;text-align:center;color:var(--muted);font-size:1rem;line-height:1.6}.faceoff-library-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));grid-gap:16px;gap:16px}.faceoff-card{border:1px solid var(--line);border-radius:14px;overflow:hidden;background:var(--surface);display:flex;flex-direction:column}.faceoff-card-preview{padding:8px;background:#eef4f9}.faceoff-card-preview svg{display:block;width:100%;height:auto;border-radius:8px}.faceoff-card-preview-fb svg{aspect-ratio:3/2;height:auto}.faceoff-card-preview-large{padding:12px;max-width:480px;margin:0 auto}.faceoff-card-body{padding:10px 12px 4px;display:flex;align-items:center;gap:8px;flex-wrap:wrap}.faceoff-card-title{font-size:.9rem;font-weight:600;color:var(--ink);flex:1 1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.faceoff-zone-badge{font-size:.7rem;font-weight:700;padding:2px 8px;border-radius:20px;white-space:nowrap;flex-shrink:0}.faceoff-zone-badge-end{background:rgba(214,40,57,.1);color:#b71c1c}.faceoff-zone-badge-neutral{background:rgba(31,122,168,.1);color:#1565c0}.faceoff-card-notes{padding:0 12px 6px;font-size:.8rem;color:var(--muted);line-height:1.4;margin:0}.faceoff-card-actions{padding:6px 12px 10px;display:flex;flex-direction:column;gap:6px}.faceoff-main-btns{display:flex;gap:6px}.faceoff-main-btn{flex:1 1;font-size:.88rem;min-height:34px}.faceoff-sub-btns{display:flex;gap:5px;flex-wrap:wrap}.faceoff-sub-btn{flex:1 1;font-size:.78rem;min-height:28px;padding:4px 8px;color:var(--muted)}.editor-mode-toggle{display:flex;border-radius:22px;overflow:hidden;border:1.5px solid var(--line);background:var(--surface);flex-shrink:0}.editor-mode-btn{padding:5px 15px;font:inherit;font-size:.82rem;font-weight:600;background:transparent;border:none;cursor:pointer;color:var(--muted);transition:background .15s,color .15s;line-height:1.4}.editor-mode-btn-drill-active{background:#d62839;color:#ffffff}.editor-mode-btn-faceoff-active{background:#1f7aa8;color:#ffffff}.editor-btn-faceoff{background:#1f7aa8!important;border-color:#1f7aa8!important}.editor-btn-faceoff:hover{background:#1a6a94!important}.rink-svg-editor-faceoff{display:block;width:100%;max-width:380px;height:auto;margin:0 auto}.rink-svg-editor-third{max-width:620px}.sticky-notes-row{display:flex;align-items:center;gap:18px;flex-wrap:wrap;padding:4px 2px 8px}.sticky-notes-hint{color:var(--muted);font-size:.82rem;font-style:italic}.sticky-note{position:relative;width:152px;min-height:152px;padding:12px 12px 34px;border-radius:2px;cursor:pointer;box-shadow:2px 4px 10px rgba(8,22,39,.13),0 1px 3px rgba(8,22,39,.07);transition:transform .16s ease,box-shadow .16s ease,width .16s ease,min-height .16s ease;-webkit-user-select:none;-moz-user-select:none;user-select:none;outline:none}.sticky-note:first-child{transform:rotate(-1.8deg)}.sticky-note:nth-child(2){transform:rotate(1.1deg)}.sticky-note:nth-child(3){transform:rotate(-.6deg)}.sticky-note:hover:not(.sticky-note-expanded){box-shadow:4px 10px 22px rgba(8,22,39,.18),0 2px 6px rgba(8,22,39,.09);z-index:2;transform:rotate(0deg) translateY(-3px)!important}.sticky-note-expanded{width:224px;min-height:196px;transform:rotate(0deg)!important;z-index:10;cursor:default;box-shadow:6px 14px 30px rgba(8,22,39,.22),0 2px 8px rgba(8,22,39,.11)}.sticky-note-fold{position:absolute;bottom:0;right:0;width:26px;height:26px;background:linear-gradient(225deg,rgba(0,0,0,.1) 50%,transparent 0);border-radius:0 0 2px 0}.sticky-note-cream{background-color:#fef8e1;background-image:repeating-linear-gradient(180deg,transparent,transparent 23px,rgba(0,0,0,.045) 0,rgba(0,0,0,.045) 24px)}.sticky-note-blue{background-color:#daeaf9}.sticky-note-blue,.sticky-note-orange{background-image:repeating-linear-gradient(180deg,transparent,transparent 23px,rgba(0,0,0,.04) 0,rgba(0,0,0,.04) 24px)}.sticky-note-orange{background-color:#fde5cc}.sticky-note-preview{margin:0;font-size:.79rem;line-height:1.55;color:rgba(12,22,36,.8);word-break:break-word;overflow:hidden;display:-webkit-box;-webkit-line-clamp:5;-webkit-box-orient:vertical;min-height:4.5em;white-space:pre-wrap}.sticky-note-placeholder{color:rgba(12,22,36,.3);font-style:italic}.sticky-note-textarea{display:block;width:100%;min-height:130px;padding:0;border:0;background:transparent;font:inherit;font-size:.8rem;line-height:1.55;color:rgba(12,22,36,.85);resize:none;outline:none;cursor:text;white-space:pre-wrap}.sticky-note-delete{position:absolute;bottom:8px;left:12px;padding:0;border:0;background:transparent;color:rgba(12,22,36,.32);font:inherit;font-size:.67rem;font-weight:700;cursor:pointer;text-transform:uppercase;letter-spacing:.06em;transition:color .12s ease}.sticky-note-delete:hover{color:var(--accent)}.sticky-note-add{display:grid;place-items:center;width:46px;height:46px;border-radius:50%;border:2px dashed rgba(15,76,129,.3);background:transparent;color:var(--primary);font-size:1.5rem;font-weight:300;line-height:1;cursor:pointer;flex-shrink:0;transition:background .14s ease,border-color .14s ease,color .14s ease}.sticky-note-add:hover{background:rgba(15,76,129,.07);border-color:rgba(15,76,129,.55);color:var(--primary-strong)}.login-page{min-height:100vh;display:grid;place-items:center;background:var(--bg);padding:24px}.login-card{display:grid;grid-gap:20px;gap:20px;width:min(420px,100%);padding:36px 32px 32px;border-radius:28px;border:1px solid rgba(16,35,58,.08);background:rgba(255,255,255,.96);box-shadow:0 12px 40px rgba(8,22,39,.12)}.login-logo{margin-bottom:4px}.login-logo,.login-logo-ring{display:flex;justify-content:center}.login-logo-ring{position:relative;width:108px;height:108px;border-radius:50%;background:radial-gradient(circle at 35% 30%,#1d5090 0,#0f3a6e 35%,#091f48 70%,#040c1e 100%);align-items:center;box-shadow:0 16px 48px rgba(0,0,0,.55),inset 0 1px 0 rgba(255,255,255,.12),0 0 0 1px rgba(255,255,255,.08)}.login-logo-ring:before{content:"";position:absolute;inset:-3px;background:conic-gradient(from -100deg,transparent 0deg,#e8620a 40deg,#e8620a 140deg,transparent 180deg,transparent 1turn);z-index:0;border-radius:50%;padding:3px;-webkit-mask:linear-gradient(#fff 0 0) content-box,linear-gradient(#fff 0 0);-webkit-mask-composite:xor;mask-composite:exclude;filter:drop-shadow(0 0 6px rgba(232,98,10,.7))}.login-logo-ring img{position:relative;z-index:1}.login-title{margin:0;font-size:2rem;font-weight:900;text-align:center;letter-spacing:.01em;color:var(--ink);-webkit-text-stroke:1.5px rgba(0,0,0,.55);paint-order:stroke fill;line-height:1.1}.login-title-x{color:#e8620a}.login-title-and{color:var(--primary-strong)}.login-brand-tagline{margin:-8px 0 0;text-align:center;font-size:.72rem;font-weight:600;letter-spacing:.2em;text-transform:uppercase;color:var(--muted);opacity:.75}.login-subtitle{margin:-4px 0 0;text-align:center;color:var(--muted);font-size:.95rem}.login-form{display:grid;grid-gap:14px;gap:14px}.login-submit{width:100%;margin-top:4px}.login-error{background:rgba(214,40,57,.08);color:var(--accent)}.login-error,.login-info{margin:0;padding:10px 14px;border-radius:12px;font-size:.88rem;font-weight:600}.login-info{background:rgba(21,127,91,.08);color:var(--success)}.login-password-label{display:flex;align-items:center;justify-content:space-between}.login-forgot{background:none;border:none;padding:0;color:var(--muted);font:inherit;font-size:.78rem;cursor:pointer;text-decoration:underline;text-underline-offset:2px}.login-toggles{display:flex;flex-direction:column;align-items:center;gap:6px}.login-toggle{background:none;border:none;padding:0;color:var(--primary);font:inherit;font-size:.88rem;font-weight:700;cursor:pointer;text-align:center;text-decoration:underline;text-underline-offset:3px}.login-legal{display:flex;align-items:center;justify-content:center;gap:8px;margin-top:4px;font-size:.75rem;color:var(--muted)}.login-legal a{color:var(--muted);text-decoration:underline;text-underline-offset:2px}.login-loading{margin:0;text-align:center;color:var(--muted)}.auth-loading{min-height:100vh;display:grid;place-items:center}.auth-loading-spinner{width:40px;height:40px;border-radius:50%;border:3px solid rgba(15,76,129,.15);border-top:3px solid var(--primary);animation:spin .7s linear infinite}@keyframes spin{to{transform:rotate(1turn)}}.nav-signout{display:inline-flex;align-items:center;min-height:30px;padding:0 12px;border-radius:10px;border:1px solid rgba(16,35,58,.12);background:transparent;color:var(--muted);font:inherit;font-size:.78rem;font-weight:700;cursor:pointer;transition:background .12s ease,color .12s ease}.nav-signout:hover{background:rgba(214,40,57,.07);color:var(--accent);border-color:rgba(214,40,57,.2)}.library-toolbar-actions{display:flex;align-items:center;gap:10px;flex-wrap:wrap;justify-content:flex-end}.library-search-wrap{position:relative}.library-search-input{min-height:44px;width:220px;padding-left:14px;padding-right:14px}@media (max-width:640px){.library-search-input,.library-toolbar-actions{width:100%}}.data-export-card{display:grid;grid-gap:12px;gap:12px;padding:22px 24px;border-radius:20px;border:1px solid rgba(16,35,58,.1);background:rgba(255,255,255,.82)}.data-export-title{margin:0;font-size:1rem;font-weight:800}.data-export-desc{margin:0;color:var(--muted);font-size:.88rem;line-height:1.6}.nav-sync-indicator{display:inline-flex;align-items:center;justify-content:center;width:28px;height:28px;border-radius:50%;font-size:.78rem;font-weight:800;flex-shrink:0;transition:opacity .3s ease}.nav-sync-syncing{background:rgba(15,76,129,.1);color:var(--primary)}.nav-sync-synced{background:rgba(21,127,91,.12);color:var(--success)}.nav-sync-error{background:rgba(214,40,57,.12);color:var(--accent)}.nav-sync-spinner{display:block;width:12px;height:12px;border-radius:50%;border:2px solid rgba(15,76,129,.2);border-top:2px solid var(--primary);animation:spin .7s linear infinite}.toast-container{position:fixed;bottom:24px;right:24px;z-index:999;display:flex;flex-direction:column;gap:10px;max-width:360px;pointer-events:none}.toast{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:12px 16px;border-radius:14px;font-size:.88rem;font-weight:600;line-height:1.4;box-shadow:0 8px 28px rgba(8,22,39,.18);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);pointer-events:all;animation:toast-in .22s ease}@keyframes toast-in{0%{opacity:0;transform:translateY(10px) scale(.97)}to{opacity:1;transform:translateY(0) scale(1)}}.toast-error{background:rgba(254,242,242,.96);border:1px solid rgba(214,40,57,.25);color:#9b1c1c}.toast-success{background:rgba(240,253,244,.96);border:1px solid rgba(21,127,91,.25);color:#14532d}.toast-info{background:rgba(239,246,255,.96);border:1px solid rgba(15,76,129,.25);color:var(--primary-strong)}.toast-close{flex-shrink:0;width:24px;height:24px;border:none;border-radius:6px;background:transparent;color:inherit;font-size:1.1rem;line-height:1;cursor:pointer;opacity:.6;display:flex;align-items:center;justify-content:center}.toast-close:hover{opacity:1;background:rgba(0,0,0,.07)}@media (max-width:480px){.toast-container{bottom:16px;right:12px;left:12px;max-width:100%}}.danger-zone-card{display:grid;grid-gap:14px;gap:14px;padding:22px 24px;border-radius:20px;border:1.5px solid rgba(214,40,57,.25);background:rgba(214,40,57,.04)}.danger-zone-title{margin:0;font-size:1rem;font-weight:800;color:var(--accent)}.danger-zone-desc{margin:0;color:var(--muted);font-size:.88rem;line-height:1.6}.button-danger{display:inline-flex;align-items:center;justify-content:center;gap:8px;min-height:44px;padding:0 18px;border-radius:14px;border:1.5px solid rgba(214,40,57,.35);background:rgba(214,40,57,.08);color:var(--accent);font:inherit;font-size:.92rem;font-weight:700;cursor:pointer;transition:background .14s ease,border-color .14s ease}.button-danger:hover:not(:disabled){background:rgba(214,40,57,.14);border-color:rgba(214,40,57,.5)}.button-danger:disabled{opacity:.45;cursor:not-allowed}.delete-dialog{display:grid;grid-gap:10px;gap:10px}.delete-dialog-prompt{margin:0;font-size:.88rem;color:var(--muted)}.delete-dialog-row{display:flex;flex-wrap:wrap;align-items:center;gap:10px}.delete-dialog-row .input{max-width:180px}.nav-hamburger{display:none;flex-direction:column;justify-content:center;gap:5px;width:44px;height:44px;padding:10px;border:none;border-radius:12px;background:rgba(16,35,58,.06);cursor:pointer;flex-shrink:0}.hamburger-bar{display:block;height:2px;border-radius:2px;background:var(--ink);transition:transform .2s ease,opacity .2s ease,width .2s ease;width:100%}.bar-open-1{transform:translateY(7px) rotate(45deg)}.bar-open-2{opacity:0;width:0}.bar-open-3{transform:translateY(-7px) rotate(-45deg)}.nav-mobile-menu{display:none;position:absolute;top:100%;left:0;right:0;z-index:30;flex-direction:column;padding:12px 16px 16px;background:rgba(247,251,255,.97);-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px);border-bottom:1px solid rgba(16,35,58,.1);box-shadow:0 12px 32px rgba(16,35,58,.12)}.nav-mobile-link{display:flex;align-items:center;min-height:46px;padding:0 14px;border-radius:14px;color:var(--muted);font-size:.95rem;font-weight:600;transition:background .14s ease,color .14s ease}.nav-mobile-link:hover{background:rgba(15,76,129,.07);color:var(--ink)}.nav-mobile-link-active{background:rgba(15,76,129,.11);color:var(--primary-strong)}.nav-mobile-divider{height:1px;background:rgba(16,35,58,.08);margin:8px 0}.nav-mobile-email{display:block;padding:8px 14px 2px;font-size:.78rem;color:var(--muted);font-weight:600}.nav-mobile-signout{display:flex;align-items:center;width:100%;min-height:44px;padding:0 14px;border-radius:14px;border:none;background:transparent;color:var(--accent);font:inherit;font-size:.92rem;font-weight:700;cursor:pointer;text-align:left;transition:background .14s ease}.nav-mobile-signout:hover{background:rgba(214,40,57,.07)}@media (max-width:980px){.nav-hamburger{display:flex;margin-left:auto}.nav-links,.nav-user{display:none}.nav{position:relative;flex-direction:row;align-items:center;flex-wrap:wrap;padding:12px 16px}.nav-mobile-menu{display:flex}.nav-help-btn{width:44px;height:44px}}@media (max-width:768px){.nav-hamburger{display:flex;margin-left:auto}.nav-links,.nav-user{display:none}.nav{position:relative;flex-direction:row;align-items:center;flex-wrap:wrap;padding:12px 16px}.nav-mobile-menu{display:flex}.page-main{padding:16px 0 32px}.hero{flex-direction:column;align-items:flex-start;gap:14px;padding:8px 0 14px}.hero h1{font-size:clamp(1.7rem,7vw,2.5rem)}.hero-actions{width:100%}.hero-actions .button,.hero-actions .button-secondary{flex:1 1;min-width:0}.dashboard-layout,.library-layout{grid-template-columns:1fr}.library-sidebar{position:static}.delete-dialog-row{flex-direction:column;align-items:stretch}.delete-dialog-row .input{max-width:100%}.footer-inner{flex-direction:column;align-items:center;gap:8px;text-align:center}}@media (max-width:480px){.nav{padding:8px 12px}.brand-logo .nav-brand-logo-img{height:44px}.brand-logo,.brand-logo img{width:44px;height:44px}.page-main{width:calc(100% - 24px)}.week-calendar-header{flex-direction:column;gap:8px}.week-calendar-header .hero-actions{display:flex;width:100%;gap:8px}.week-calendar-header .hero-actions button{flex:1 1}.login-logo img{width:180px!important}.layout-split{grid-template-columns:1fr}}.landing{min-height:100vh;background:#0f1923;color:#fff;font-family:inherit}.landing-nav{position:-webkit-sticky;position:sticky;top:0;z-index:100;background:rgba(15,25,35,.92);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-bottom:1px solid rgba(255,255,255,.07)}.landing-nav-inner{max-width:1100px;margin:0 auto;padding:10px 24px;display:flex;align-items:center;justify-content:space-between;gap:16px}.landing-brand{display:flex;align-items:center;gap:2px;text-decoration:none;color:inherit;min-width:0}.landing-brand-logo{height:78px;width:auto;display:block}.landing-logo-pill{background:#ffffff;border-radius:10px;padding:5px 12px;display:flex;align-items:center}.landing-brand-name{font-size:1.35rem;font-weight:800;letter-spacing:-.02em;color:#fff}.landing-brand-x{color:#e8620a}.landing-brand-and{color:rgba(255,255,255,.55);font-weight:600;font-size:.85em}.landing-brand-o{color:#e8620a}.landing-nav-actions{display:flex;align-items:center;gap:12px}.landing-nav-login{color:rgba(255,255,255,.7);text-decoration:none;font-size:.9rem;transition:color .15s}.landing-nav-login:hover{color:#fff}.landing-nav-cta{font-size:.88rem;padding:8px 18px}.landing-hero{padding:80px 24px 60px;background:radial-gradient(ellipse at 70% 30%,rgba(15,76,129,.25) 0,transparent 60%)}.landing-hero-inner{max-width:1100px;margin:0 auto;display:grid;grid-template-columns:1fr 1fr;grid-gap:60px;gap:60px;align-items:center}.landing-hero-eyebrow{font-size:.8rem;font-weight:600;letter-spacing:.12em;text-transform:uppercase;color:#e8620a;margin:0 0 16px}.landing-hero-headline{font-size:clamp(2rem,4vw,3.2rem);font-weight:800;line-height:1.15;margin:0 0 20px;letter-spacing:-.02em}.landing-hero-accent{color:#e8620a}.landing-floorball .landing-hero-accent,.landing-floorball .landing-hero-eyebrow,.landing-floorball .landing-section-eyebrow{color:#16a34a}.landing-floorball .landing-feature-card--accent{border-color:rgba(22,163,74,.28);background:linear-gradient(135deg,#0f2a3d 60%,rgba(22,163,74,.07))}.landing-floorball .landing-pwa-badge{background:rgba(22,163,74,.15);color:#34d399}.landing-floorball .landing-tagline-dot{color:#16a34a}.sport-chooser{min-height:100vh;display:flex;flex-direction:column;background:radial-gradient(ellipse at 50% -10%,rgba(15,76,129,.38) 0,transparent 60%),#0f1923;color:#f5f2eb;padding:24px}.sport-chooser-top{display:flex;align-items:center;justify-content:space-between;max-width:1080px;width:100%;margin:0 auto}.sport-chooser-logo{display:flex;align-items:center;gap:10px}.sport-chooser-logo-img{height:64px;width:auto;display:block}.sport-chooser-logo-text{font-size:1.3rem;font-weight:800;letter-spacing:-.02em;color:#fff}.sport-chooser-hero{text-align:center;max-width:720px;margin:52px auto 40px}.sport-chooser-eyebrow{font-size:.8rem;font-weight:600;letter-spacing:.18em;text-transform:uppercase;color:#5aabee;margin:0 0 12px}.sport-chooser-headline{font-size:clamp(2rem,5vw,3.2rem);font-weight:800;letter-spacing:-.02em;margin:0 0 14px;color:#fff}.sport-chooser-sub{font-size:1.05rem;color:rgba(245,242,235,.72);margin:0}.sport-chooser-cards{display:grid;grid-template-columns:1fr 1fr;grid-gap:28px;gap:28px;max-width:1000px;width:100%;margin:0 auto auto;padding-bottom:40px}.sport-chooser-card{display:flex;flex-direction:column;background:#13202e;border:1px solid rgba(255,255,255,.08);border-radius:20px;overflow:hidden;text-decoration:none;color:inherit;transition:transform .18s ease,border-color .18s ease,box-shadow .18s ease}.sport-chooser-card:hover{transform:translateY(-6px);box-shadow:0 20px 50px rgba(0,0,0,.4)}.sport-chooser-card--hockey:hover{border-color:rgba(232,98,10,.55)}.sport-chooser-card--floorball:hover{border-color:rgba(22,163,74,.55)}.sport-chooser-card-visual{background:linear-gradient(160deg,#0e1a26,#0a1622);padding:26px 26px 8px}.sport-chooser-field{width:100%;height:auto;display:block;filter:drop-shadow(0 6px 16px rgba(0,0,0,.35))}.sport-chooser-card-body{padding:22px 26px 28px;display:flex;flex-direction:column;gap:4px}.sport-chooser-card-brand{font-size:.72rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase}.sport-chooser-card--hockey .sport-chooser-card-brand{color:#e8620a}.sport-chooser-card--floorball .sport-chooser-card-brand{color:#16a34a}.sport-chooser-card-name{font-size:1.6rem;font-weight:800;margin:2px 0 4px;color:#fff}.sport-chooser-card-tag{font-size:.95rem;color:rgba(245,242,235,.7);margin:0 0 14px}.sport-chooser-card-cta{font-weight:700;font-size:.95rem}.sport-chooser-card--hockey .sport-chooser-card-cta{color:#e8620a}.sport-chooser-card--floorball .sport-chooser-card-cta{color:#34d399}.sport-chooser-footer{display:flex;gap:14px;justify-content:center;padding:20px}.sport-chooser-footer a{color:rgba(245,242,235,.6);text-decoration:none}.sport-chooser-footer a:hover{color:#fff}@media (max-width:720px){.sport-chooser-cards{grid-template-columns:1fr}}.landing-hero-sub{font-size:1.05rem;line-height:1.65;color:rgba(255,255,255,.65);margin:0 0 36px;max-width:480px}.landing-hero-actions{display:flex;gap:12px;flex-wrap:wrap}.landing-cta-primary{background:#e8620a;color:#fff;font-weight:700;padding:13px 28px;font-size:1rem;border-radius:8px;border:none;text-decoration:none;display:inline-block;transition:background .15s,transform .1s}.landing-cta-primary:hover{background:#d4560a;transform:translateY(-1px)}.landing-cta-secondary{padding:13px 24px;font-size:1rem;text-decoration:none;display:inline-block;color:rgba(255,255,255,.8);background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.12);border-radius:8px;transition:background .15s}.landing-cta-secondary:hover{background:rgba(255,255,255,.1);color:#fff}.landing-hero-visual{display:flex;justify-content:center}.landing-rink-card{background:#0f2a3d;border:1px solid rgba(255,255,255,.1);border-radius:12px;overflow:hidden;box-shadow:0 24px 64px rgba(0,0,0,.5);width:100%;max-width:460px}.landing-rink-bar{background:#0a1e2d;padding:10px 14px;display:flex;align-items:center;gap:6px;border-bottom:1px solid rgba(255,255,255,.07)}.landing-rink-dot{width:10px;height:10px;border-radius:50%;background:rgba(255,255,255,.15);display:inline-block}.landing-rink-label{margin-left:8px;font-size:.75rem;color:rgba(255,255,255,.4);font-family:monospace}.landing-rink-svg{width:100%;height:auto;display:block;padding:12px}.landing-features{padding:80px 24px;background:rgba(255,255,255,.02)}.landing-section-inner{max-width:1100px;margin:0 auto}.landing-section-eyebrow{font-size:.78rem;font-weight:600;letter-spacing:.12em;text-transform:uppercase;color:#e8620a;margin:0 0 12px;text-align:center}.landing-section-title{font-size:clamp(1.5rem,3vw,2.2rem);font-weight:700;text-align:center;margin:0 0 52px;letter-spacing:-.02em}.landing-features-grid{display:grid;grid-template-columns:repeat(3,1fr);grid-gap:20px;gap:20px}.landing-feature-card{background:#0f2a3d;border:1px solid rgba(255,255,255,.07);border-radius:12px;padding:28px 24px;transition:border-color .2s,transform .2s}.landing-feature-card:hover{border-color:rgba(232,98,10,.35);transform:translateY(-2px)}.landing-feature-card--accent{border-color:rgba(232,98,10,.25);background:linear-gradient(135deg,#0f2a3d 60%,rgba(232,98,10,.06))}.landing-feature-icon{width:48px;height:48px;border-radius:10px;background:rgba(15,76,129,.4);display:flex;align-items:center;justify-content:center;margin-bottom:18px;color:#fff}.landing-feature-card h3{font-size:1.05rem;font-weight:700;margin:0 0 10px;color:#fff}.landing-feature-card p{font-size:.88rem;line-height:1.65;color:rgba(255,255,255,.55);margin:0}.share-modal-backdrop{position:fixed;inset:0;background:rgba(10,18,30,.55);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:9000;display:flex;align-items:center;justify-content:center}.share-modal{background:var(--surface-strong);border:1px solid var(--line);border-radius:18px;box-shadow:0 28px 72px rgba(10,18,30,.45);padding:28px;width:min(480px,calc(100vw - 32px));display:flex;flex-direction:column;gap:16px}.share-modal-title{font-size:1.15rem;font-weight:700;margin:0}.share-modal-drill-name{font-size:.9rem;color:var(--muted);margin:-8px 0 0}.share-url-row{display:flex;gap:8px;align-items:stretch}.share-url-input{flex:1 1;min-width:0;font-size:.82rem;background:var(--surface);cursor:text}.share-copy-btn{flex-shrink:0}.share-btn-row{display:flex;gap:10px;flex-wrap:wrap}.share-whatsapp-btn{display:flex;align-items:center;background:#25d366!important;color:white!important;text-decoration:none}.share-whatsapp-btn:hover{background:#20bd5a!important}.view-page{min-height:100vh;background:var(--bg)}.view-header{position:-webkit-sticky;position:sticky;top:0;z-index:100;background:rgba(247,251,255,.95);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-bottom:1px solid var(--line);padding:12px 24px;justify-content:space-between}.view-brand,.view-header{display:flex;align-items:center}.view-brand{gap:10px;font-weight:700;font-size:1rem;color:var(--ink);text-decoration:none}.view-cta{font-size:.88rem}.view-main{max-width:860px;margin:0 auto;padding:32px 24px 64px}.view-not-found{text-align:center;padding:80px 0;display:flex;flex-direction:column;align-items:center;gap:16px}.view-drill-header{display:flex;flex-direction:column;gap:10px;margin-bottom:28px}.view-drill-title{font-size:1.8rem;font-weight:800;margin:0;letter-spacing:-.02em}.view-drill-meta{display:flex;gap:12px;flex-wrap:wrap;font-size:.88rem;color:var(--muted)}.view-drill-meta span:before{content:"·";margin-right:12px}.view-drill-meta span:first-child:before{content:"";margin:0}.view-drill-canvases{display:flex;flex-direction:column;gap:20px;margin-bottom:24px}.view-phase-title{font-size:1rem;font-weight:600;margin:0 0 10px;color:var(--muted)}.view-canvas-wrap{border-radius:12px;overflow:hidden;border:1px solid var(--line)}.view-drill-description{font-size:.95rem;line-height:1.65;color:var(--muted);margin:0 0 28px}.view-plan-items{list-style:none;padding:0;margin:0 0 28px;display:flex;flex-direction:column;gap:10px}.view-plan-item{background:var(--surface);border:1px solid var(--line);border-radius:10px;padding:14px 18px}.view-plan-item-header{display:flex;align-items:center;gap:12px}.view-plan-num{width:26px;height:26px;border-radius:50%;background:var(--primary);color:#fff;font-size:.8rem;font-weight:700;display:flex;align-items:center;justify-content:center;flex-shrink:0}.view-plan-item-header strong{flex:1 1;font-size:.95rem}.view-plan-meta{flex-shrink:0}.view-plan-focus,.view-plan-meta{font-size:.82rem;color:var(--muted)}.view-plan-focus{margin:6px 0 0 38px}.view-drill-cta{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:20px 24px;background:rgba(15,76,129,.06);border:1px solid rgba(15,76,129,.15);border-radius:14px;flex-wrap:wrap}.view-drill-cta p{font-size:.95rem;color:var(--ink);font-weight:500;margin:0}.nav-help-btn{display:flex;align-items:center;justify-content:center;width:40px;height:40px;border-radius:50%;color:var(--muted);border:1.5px solid transparent;transition:color .15s,border-color .15s,background .15s;flex-shrink:0}.nav-help-btn:hover{color:var(--primary);background:rgba(15,76,129,.08);border-color:rgba(15,76,129,.2)}.nav-help-btn-active{color:var(--primary-strong);background:rgba(15,76,129,.1);border-color:rgba(15,76,129,.25)}.ohjeet-intro{background:linear-gradient(135deg,rgba(15,76,129,.08),transparent 60%);border:1px solid rgba(15,76,129,.12);border-radius:16px;padding:28px 32px;margin-bottom:28px}.ohjeet-intro-inner{max-width:680px}.ohjeet-intro-title{font-size:1.15rem;font-weight:700;margin:0 0 12px;color:var(--primary-strong)}.ohjeet-intro p{font-size:.92rem;line-height:1.65;color:var(--muted);margin:0 0 8px}.ohjeet-intro p:last-child{margin:0}.ohjeet-grid{display:flex;flex-direction:column;gap:10px}.ohjeet-card{background:var(--surface);border:1px solid var(--border);border-radius:14px;overflow:hidden;transition:border-color .15s}.ohjeet-card:hover{border-color:rgba(15,76,129,.25)}.ohjeet-card-open{border-color:rgba(15,76,129,.3);background:var(--surface-strong)}.ohjeet-card-header{width:100%;display:flex;align-items:center;gap:14px;padding:16px 20px;background:none;border:none;cursor:pointer;text-align:left;font:inherit;transition:background .12s}.ohjeet-card-header:hover{background:rgba(15,76,129,.04)}.ohjeet-card-emoji{font-size:1.4rem;flex-shrink:0;line-height:1}.ohjeet-card-title{font-size:1rem;font-weight:700;color:var(--ink);flex-shrink:0;min-width:160px}.ohjeet-card-summary{font-size:.85rem;color:var(--muted);flex:1 1;line-height:1.4}.ohjeet-card-chevron{font-size:.7rem;color:var(--muted);flex-shrink:0;opacity:.6}.ohjeet-card-tips{list-style:none;margin:0;padding:0 20px 18px;display:flex;flex-direction:column;gap:8px;border-top:1px solid var(--border)}.ohjeet-card-tips li{font-size:.88rem;line-height:1.55;color:var(--ink);padding:8px 0 0 20px;position:relative}.ohjeet-card-tips li:before{content:"›";position:absolute;left:4px;color:var(--primary);font-weight:700;font-size:1rem}@media (max-width:640px){.ohjeet-card-summary{display:none}.ohjeet-card-title{min-width:auto}}.landing-pwa{padding:52px 24px;background:rgba(232,98,10,.06);border-top:1px solid rgba(232,98,10,.15);border-bottom:1px solid rgba(232,98,10,.15)}.landing-pwa-inner{display:grid;grid-template-columns:1fr 1fr;grid-gap:52px;gap:52px;align-items:center}.landing-pwa-badge{display:inline-flex;align-items:center;gap:6px;background:rgba(232,98,10,.15);border:1px solid rgba(232,98,10,.3);color:#e8620a;font-size:.78rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase;padding:4px 12px;border-radius:20px;margin-bottom:14px}.landing-pwa-title{font-size:clamp(1.4rem,2.5vw,2rem);font-weight:800;margin:0 0 14px;letter-spacing:-.02em;line-height:1.2;color:#fff}.landing-pwa-desc{font-size:.95rem;line-height:1.65;color:rgba(255,255,255,.65);margin:0}.landing-pwa-steps{display:flex;flex-direction:column;gap:12px}.landing-pwa-step{display:flex;align-items:flex-start;gap:14px;background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.08);border-radius:12px;padding:14px 16px;transition:border-color .15s}.landing-pwa-step:hover{border-color:rgba(232,98,10,.3)}.landing-pwa-step-icon{width:24px;height:24px;display:flex;align-items:center;justify-content:center;color:#e8620a;flex-shrink:0;margin-top:2px}.landing-pwa-step-icon-svg{width:24px;height:24px;display:block}.landing-pwa-step strong{display:block;font-size:.88rem;font-weight:700;color:#fff;margin-bottom:4px}.landing-pwa-step p{font-size:.82rem;color:rgba(255,255,255,.55);margin:0;line-height:1.5}.landing-pwa-step em{color:#e8620a;font-style:normal;font-weight:600}.landing-pwa-key{display:inline-block;background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.2);border-radius:4px;padding:1px 6px;font-size:.8rem;font-family:monospace;color:rgba(255,255,255,.85);margin:0 2px}@media (max-width:768px){.landing-pwa-inner{grid-template-columns:1fr;gap:28px}}.landing-how{padding:80px 24px}.landing-steps{display:flex;align-items:flex-start;gap:0;margin-top:48px}.landing-step{flex:1 1;text-align:center;padding:0 20px}.landing-step-num{width:52px;height:52px;border-radius:50%;background:#0f4c81;color:#fff;font-size:1.3rem;font-weight:800;display:flex;align-items:center;justify-content:center;margin:0 auto 18px;border:2px solid rgba(232,98,10,.4)}.landing-step h3{font-size:1.05rem;font-weight:700;margin:0 0 10px}.pricing-section-inner{max-width:880px;margin:0 auto;padding:0 24px}.pricing-hero{padding:72px 0 48px;background:radial-gradient(ellipse at 50% 0,rgba(15,76,129,.28) 0,transparent 62%);text-align:center}.pricing-hero-inner{display:flex;flex-direction:column;align-items:center}.pricing-eyebrow{display:inline-block;padding:6px 14px;border-radius:999px;background:rgba(232,98,10,.16);border:1px solid rgba(232,98,10,.4);color:#e8620a;font-size:.78rem;font-weight:800;letter-spacing:.1em;text-transform:uppercase;margin-bottom:22px}.pricing-hero-title{font-size:clamp(1.9rem,4vw,2.8rem);font-weight:900;letter-spacing:-.02em;line-height:1.1;margin:0 0 20px;max-width:16ch}.pricing-hero-body{font-size:1.08rem;line-height:1.65;color:rgba(255,255,255,.82);max-width:56ch;margin:0 0 16px}.pricing-hero-note{font-size:.92rem;color:rgba(255,255,255,.55);margin:0 0 30px}.pricing-hero-actions{display:flex;gap:14px;flex-wrap:wrap;justify-content:center}.pricing-cta-primary{font-size:.98rem;padding:12px 28px}.pricing-cta-secondary{font-size:.98rem;padding:12px 24px;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.18);color:#fff}.pricing-cta-secondary:hover{background:rgba(255,255,255,.12)}.pricing-cta-large{padding:14px 34px;font-size:1.05rem}.pricing-card-section{padding:8px 0 56px}.pricing-card{max-width:440px;margin:0 auto;background:linear-gradient(165deg,rgba(255,255,255,.07),rgba(255,255,255,.03));border:1px solid rgba(232,98,10,.32);border-radius:22px;padding:32px 30px;box-shadow:0 24px 60px -30px rgba(0,0,0,.7)}.pricing-card-head{text-align:center;padding-bottom:22px;border-bottom:1px solid rgba(255,255,255,.1);margin-bottom:22px}.pricing-card-plan{display:inline-block;font-size:.82rem;font-weight:800;letter-spacing:.12em;text-transform:uppercase;color:#e8620a;margin-bottom:12px}.pricing-card-price-row{display:flex;align-items:baseline;justify-content:center;gap:8px}.pricing-card-price{font-size:3rem;font-weight:900;letter-spacing:-.02em;color:#fff}.pricing-card-price-suffix{font-size:.95rem;color:rgba(255,255,255,.55)}.pricing-feature-list{list-style:none;padding:0;margin:0 0 26px;display:flex;flex-direction:column;gap:13px}.pricing-feature-item{display:flex;align-items:flex-start;gap:11px;font-size:.95rem;line-height:1.4;color:rgba(255,255,255,.88)}.pricing-feature-check{flex-shrink:0;margin-top:1px}.pricing-card-cta{display:block;width:100%;text-align:center;padding:13px;font-size:1rem;margin-bottom:18px}.pricing-card-note{font-size:.85rem;line-height:1.5;color:rgba(255,255,255,.5);text-align:center;margin:0}.pricing-block{padding:52px 0;border-top:1px solid rgba(255,255,255,.06)}.pricing-block-muted{background:rgba(255,255,255,.02)}.pricing-block-inner{max-width:720px}.pricing-block-title{font-size:clamp(1.5rem,3vw,1.9rem);font-weight:800;letter-spacing:-.01em;margin:0 0 18px}.pricing-block-body{font-size:1.05rem;line-height:1.7;color:rgba(255,255,255,.82);margin:0 0 18px}.pricing-block-subbody{font-size:.98rem;line-height:1.65;color:rgba(255,255,255,.6);margin:0}.pricing-bullet-list{list-style:none;padding:0;margin:24px 0 0;display:grid;grid-gap:14px;gap:14px}.pricing-bullet-item{display:flex;align-items:flex-start;gap:11px;font-size:1rem;line-height:1.45;color:rgba(255,255,255,.88)}.pricing-faq-list{display:grid;grid-gap:8px;gap:8px;margin-top:24px}.pricing-faq-item{padding:20px 22px;border-radius:14px;background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.07)}.pricing-faq-question{font-size:1.02rem;font-weight:700;margin:0 0 8px;color:#fff}.pricing-faq-answer{font-size:.96rem;line-height:1.6;color:rgba(255,255,255,.72);margin:0}.pricing-bottom-cta{padding:64px 0 72px;text-align:center;background:radial-gradient(ellipse at 50% 100%,rgba(15,76,129,.3) 0,transparent 60%);border-top:1px solid rgba(255,255,255,.06)}.pricing-bottom-cta-inner{display:flex;flex-direction:column;align-items:center}.pricing-bottom-cta-title{font-size:clamp(1.6rem,3.4vw,2.2rem);font-weight:900;letter-spacing:-.02em;margin:0 0 16px;max-width:20ch}.pricing-bottom-cta-body{font-size:1.05rem;line-height:1.65;color:rgba(255,255,255,.78);max-width:52ch;margin:0 0 28px}.pricing-footer{padding:28px 0;border-top:1px solid rgba(255,255,255,.08)}.pricing-footer-inner{display:flex;align-items:center;justify-content:space-between;gap:16px;flex-wrap:wrap}.pricing-footer-copy{font-size:.85rem;color:rgba(255,255,255,.5)}.pricing-footer-links{display:flex;align-items:center;gap:12px;font-size:.85rem}.pricing-footer-links a{color:rgba(255,255,255,.6);text-decoration:none;transition:color .15s}.pricing-footer-links a:hover{color:#fff}.pricing-footer-links span{color:rgba(255,255,255,.25)}@media (max-width:620px){.pricing-hero{padding:48px 0 36px}.pricing-card{padding:26px 22px}.pricing-block{padding:40px 0}.pricing-footer-inner{flex-direction:column;text-align:center}}.landing-step p{font-size:.88rem;line-height:1.65;color:rgba(255,255,255,.55);margin:0}.landing-step-arrow{font-size:1.5rem;color:rgba(232,98,10,.5);padding-top:14px;flex-shrink:0}.landing-bottom-cta{padding:80px 24px;background:linear-gradient(135deg,#0f2a3d,rgba(15,76,129,.3));border-top:1px solid rgba(255,255,255,.07);border-bottom:1px solid rgba(255,255,255,.07)}.landing-bottom-cta-inner{text-align:center}.landing-bottom-cta h2{font-size:clamp(1.6rem,3vw,2.4rem);font-weight:800;margin:0 0 12px;letter-spacing:-.02em}.landing-bottom-cta p{color:rgba(255,255,255,.6);font-size:1rem;margin:0 0 32px}.landing-cta-large{padding:16px 40px;font-size:1.1rem}.landing-footer{padding:24px;border-top:1px solid rgba(255,255,255,.07)}.landing-footer-inner{max-width:1100px;margin:0 auto;display:flex;align-items:center;justify-content:space-between;gap:16px}.landing-footer-links{display:flex;align-items:center;gap:10px;font-size:.82rem;color:rgba(255,255,255,.4)}.landing-footer-links a{color:rgba(255,255,255,.4);text-decoration:none;transition:color .15s}.landing-footer-links a:hover{color:rgba(255,255,255,.7)}@media (max-width:900px){.landing-hero-inner{grid-template-columns:1fr;gap:40px;text-align:center}.landing-hero-sub{margin-left:auto;margin-right:auto}.landing-hero-actions{justify-content:center}.landing-features-grid{grid-template-columns:1fr 1fr}.landing-steps{flex-direction:column;align-items:center;gap:8px}.landing-step-arrow{transform:rotate(90deg);padding:0}}@media (max-width:600px){.landing-nav-login{display:none}.landing-nav-inner{padding:10px 14px;gap:10px}.landing-brand-logo{height:48px}.landing-brand-name{display:none}.landing-nav-cta{font-size:.8rem;padding:7px 12px}.landing-features-grid{grid-template-columns:1fr}.landing-footer-inner{flex-direction:column;text-align:center;gap:12px}}.cookie-banner{position:fixed;bottom:0;left:0;right:0;z-index:9999;background:#0f2a3d;border-top:1px solid rgba(255,255,255,.1);padding:14px 24px;display:flex;align-items:center;justify-content:center;gap:20px;flex-wrap:wrap}.cookie-banner-text{margin:0;font-size:.85rem;color:rgba(255,255,255,.75);line-height:1.5;max-width:680px;text-align:center}.cookie-banner-link{color:#e8620a;text-decoration:underline}.cookie-banner-btn{flex-shrink:0;font-size:.85rem;padding:7px 20px;white-space:nowrap}.landing-hero-img-wrap{position:relative;width:100%;max-width:600px}.landing-hero-img{width:100%;height:auto;border-radius:20px;display:block;-webkit-mask-image:linear-gradient(90deg,transparent 0,black 6%,black 94%,transparent),linear-gradient(180deg,transparent 0,black 4%,black 88%,transparent);mask-image:linear-gradient(90deg,transparent 0,black 6%,black 94%,transparent),linear-gradient(180deg,transparent 0,black 4%,black 88%,transparent);-webkit-mask-composite:destination-in;mask-composite:intersect}.landing-tagline{display:flex;align-items:center;justify-content:center;gap:16px;padding:20px 24px 0;text-align:center}.landing-tagline p{font-size:1.1rem;font-style:italic;color:#e8620a;letter-spacing:.02em;margin:0;font-weight:600}.landing-tagline-dot{color:#e8620a;font-size:.5rem;opacity:.6;flex-shrink:0}.sub-chip{display:inline-flex;align-items:center;gap:5px;font-size:.8rem;font-weight:700;padding:3px 10px;border-radius:20px}.sub-chip-active{background:rgba(34,197,94,.12);color:#16a34a}.sub-chip-trial{background:rgba(245,158,11,.12);color:#b45309}.fc-root{max-width:560px;margin:0 auto;-webkit-user-select:none;-moz-user-select:none;user-select:none}.fc-root,.fc-viewport{position:relative;width:100%}.fc-viewport{perspective:1100px;overflow:hidden;height:360px}.fc-track{position:relative;width:100%;height:100%;transform-style:preserve-3d}.fc-card{position:absolute;top:50%;left:50%;width:340px;height:310px;transform-origin:center center;border-radius:20px;background:rgba(12,22,38,.96);border:1px solid rgba(255,255,255,.09);overflow:hidden;display:flex;flex-direction:column;cursor:pointer;transition:transform .42s cubic-bezier(.4,0,.2,1),opacity .42s cubic-bezier(.4,0,.2,1),box-shadow .42s ease}.fc-card:before{content:"";position:absolute;top:0;left:0;right:0;height:2px;background:linear-gradient(90deg,transparent 0,var(--accent) 50%,transparent 100%);opacity:0;transition:opacity .3s}.fc-card-active:before{opacity:1}.fc-card-active{transform:translate(-50%,-50%) translateX(0) scale(1) rotateY(0deg);opacity:1;box-shadow:0 28px 72px rgba(0,0,0,.55),0 0 0 1px rgba(255,255,255,.12),0 0 60px rgba(15,76,129,.15);cursor:default;z-index:10}.fc-card-next{transform:translate(-50%,-50%) translateX(74%) scale(.84) rotateY(-16deg);opacity:.42;z-index:5}.fc-card-prev{transform:translate(-50%,-50%) translateX(-74%) scale(.84) rotateY(16deg);opacity:.42;z-index:5}.fc-card-next2{transform:translate(-50%,-50%) translateX(126%) scale(.68) rotateY(-28deg);opacity:.14;z-index:2}.fc-card-prev2{transform:translate(-50%,-50%) translateX(-126%) scale(.68) rotateY(28deg);opacity:.14;z-index:2}.fc-card-hidden{transform:translate(-50%,-50%) translateX(160%) scale(.5);opacity:0;pointer-events:none;z-index:0}.fc-card-visual{flex:1 1;position:relative;overflow:hidden;border-radius:18px 18px 0 0;min-height:210px}.fc-card-img{object-fit:cover;object-position:center top;border-radius:18px 18px 0 0}.fc-card-svg{width:100%;height:100%;max-height:214px;display:block}.fc-card-visual svg:not(.fc-card-svg){width:100%;height:100%;max-height:200px}.fc-card-body{padding:12px 22px 20px;background:linear-gradient(0deg,rgba(8,16,28,.9),transparent)}.fc-card-title{font-size:1.05rem;font-weight:700;color:#fff;margin:0 0 4px;letter-spacing:-.01em}.fc-card-desc{font-size:.82rem;color:rgba(180,200,220,.75);margin:0;line-height:1.4}.fc-card-shine{position:absolute;inset:0;background:linear-gradient(135deg,rgba(255,255,255,.04),transparent 50%);pointer-events:none;border-radius:20px}.fc-arrow{position:absolute;top:50%;transform:translateY(-50%);width:40px;height:40px;border-radius:50%;border:1px solid rgba(255,255,255,.15);background:rgba(10,20,35,.75);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:background .2s,border-color .2s,transform .15s;z-index:20}.fc-arrow:hover{background:rgba(15,76,129,.7);border-color:rgba(255,255,255,.3)}.fc-arrow:active{transform:translateY(-50%) scale(.93)}.fc-arrow-left{left:-20px}.fc-arrow-right{right:-20px}.fc-dots{display:flex;justify-content:center;gap:8px;margin-top:20px}.fc-dot{width:7px;height:7px;border-radius:50%;background:rgba(255,255,255,.2);border:none;cursor:pointer;transition:background .25s,transform .25s,width .25s;padding:0}.fc-dot-active{background:#e8620a;width:22px;border-radius:4px;transform:none}@media (max-width:520px){.fc-viewport{height:300px}.fc-card{width:260px;height:260px}.fc-card-next{transform:translate(-50%,-50%) translateX(68%) scale(.8) rotateY(-14deg)}.fc-card-prev{transform:translate(-50%,-50%) translateX(-68%) scale(.8) rotateY(14deg)}.fc-arrow-left{left:-10px}.fc-arrow-right{right:-10px}}.admin-shell{max-width:900px;margin:0 auto;padding:32px 24px 64px}.admin-header{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;margin-bottom:28px}.admin-title{font-size:1.7rem;font-weight:800;margin:0 0 4px;letter-spacing:-.02em}.admin-subtitle{color:var(--muted);margin:0;font-size:.9rem}.admin-stats-row{display:flex;gap:12px;flex-wrap:wrap;margin-bottom:24px}.admin-stat-chip{display:flex;align-items:center;gap:8px;background:var(--surface);border:1px solid var(--border);border-radius:10px;padding:10px 16px;font-size:.85rem;color:var(--muted)}.admin-stat-num{font-size:1.3rem;font-weight:800;color:var(--ink);line-height:1}.admin-error{background:rgba(239,68,68,.08);border:1px solid rgba(239,68,68,.25);color:#ef4444;border-radius:10px;padding:12px 16px;margin-bottom:16px;font-size:.9rem}.admin-user-card,.admin-user-list{display:flex;flex-direction:column;gap:12px}.admin-user-card{background:var(--surface);border:1px solid var(--border);border-radius:14px;padding:18px 20px}.admin-user-header{display:flex;align-items:flex-start;justify-content:space-between;gap:12px}.admin-user-info{display:flex;flex-direction:column;gap:4px;min-width:0}.admin-user-email{font-weight:700;font-size:.95rem;display:flex;align-items:center;gap:8px;flex-wrap:wrap}.admin-user-meta{font-size:.8rem;color:var(--muted)}.admin-user-ends{background:rgba(15,76,129,.07);padding:4px 10px;border-radius:6px;width:-moz-fit-content;width:fit-content}.admin-user-ends,.admin-user-notes{font-size:.82rem;color:var(--muted)}.admin-user-notes{font-style:italic}.admin-user-activity{display:flex;align-items:center;gap:8px;flex-wrap:wrap;margin-top:4px;font-size:.8rem}.admin-activity-chip{background:rgba(15,76,129,.08);color:var(--primary);border-radius:20px;padding:2px 10px;font-size:.76rem;font-weight:600}.admin-status-badge{flex-shrink:0;font-size:.72rem;font-weight:700;letter-spacing:.06em;padding:3px 10px}.admin-badge-admin,.admin-status-badge{color:#fff;text-transform:uppercase;border-radius:20px}.admin-badge-admin{background:var(--primary);font-size:.65rem;font-weight:800;letter-spacing:.08em;padding:2px 7px}.admin-user-actions{display:flex;flex-wrap:wrap;gap:8px;align-items:center}.admin-billing-badge{font-size:.82rem;font-weight:700;color:#0f4c81;background:rgba(15,76,129,.1);border:1px solid rgba(15,76,129,.2);border-radius:8px;padding:6px 12px}.admin-edit-form{display:flex;flex-direction:column;gap:12px;padding-top:4px;border-top:1px solid var(--border)}.subscribe-hero-col{display:flex;align-items:flex-start;justify-content:center;padding-top:8px}.subscribe-hero-img{width:100%;max-width:480px;height:auto;display:block;border-radius:16px;-webkit-mask-image:linear-gradient(90deg,transparent 0,black 12%,black 88%,transparent),linear-gradient(180deg,transparent 0,black 6%,black 82%,transparent);mask-image:linear-gradient(90deg,transparent 0,black 12%,black 88%,transparent),linear-gradient(180deg,transparent 0,black 6%,black 82%,transparent);-webkit-mask-composite:destination-in;mask-composite:intersect}.subscribe-status-banner{border-radius:12px;padding:14px 18px;font-size:.95rem;font-weight:600;margin-bottom:24px;max-width:860px}.subscribe-status-banner-trial{background:rgba(245,158,11,.1);border:1px solid rgba(245,158,11,.3);color:#92400e}.subscribe-status-banner-suspended{background:rgba(239,68,68,.08);border:1px solid rgba(239,68,68,.25);color:#991b1b}.subscribe-layout{display:grid;grid-template-columns:300px 1fr 420px;grid-gap:32px;gap:32px;align-items:flex-start;max-width:1200px}.subscribe-info-card{background:var(--primary);color:#fff;border-radius:16px;padding:28px 24px;position:-webkit-sticky;position:sticky;top:100px}.subscribe-info-card h3{margin:0 0 8px;font-size:1.2rem;font-weight:800}.subscribe-price{font-size:1.5rem;font-weight:800;margin-bottom:24px;color:#e8620a}.subscribe-features{list-style:none;padding:0;margin:0 0 24px;display:flex;flex-direction:column;gap:10px;font-size:.9rem;line-height:1.4}.subscribe-price-sub{font-size:.82rem;color:rgba(255,255,255,.65);margin-top:-16px;margin-bottom:20px}.subscribe-period-selector{display:grid;grid-template-columns:1fr 1fr;grid-gap:10px;gap:10px;margin-bottom:4px}.subscribe-period-option{display:flex;flex-direction:column;align-items:center;gap:4px;padding:14px 10px;border-radius:12px;border:2px solid var(--border);background:var(--surface);cursor:pointer;transition:border-color .15s,background .15s;position:relative}.subscribe-period-option:hover{border-color:var(--primary)}.subscribe-period-option-active{border-color:var(--primary);background:rgba(15,76,129,.06)}.subscribe-period-label{font-size:.85rem;font-weight:600;color:var(--ink)}.subscribe-period-price{font-size:1.15rem;font-weight:800;color:var(--primary)}.subscribe-period-badge{position:absolute;top:-10px;right:-6px;background:#e8620a;color:#fff;font-size:.68rem;font-weight:700;padding:2px 8px;border-radius:20px;white-space:nowrap}.subscribe-contact-note{font-size:.8rem;opacity:.75;line-height:1.6;border-top:1px solid rgba(255,255,255,.15);padding-top:16px;margin-top:8px}.subscribe-form{background:var(--surface);border:1px solid var(--border);border-radius:16px;padding:28px 24px;display:flex;flex-direction:column;gap:16px}.subscribe-type-toggle{display:flex;gap:8px}.subscribe-submitted{max-width:480px;margin:48px auto;text-align:center;display:flex;flex-direction:column;gap:16px}.subscribe-submitted-icon{width:72px;height:72px;background:#22c55e;color:#fff;font-size:2rem;border-radius:50%;display:flex;align-items:center;justify-content:center;margin:0 auto}.subscribe-submitted h2{margin:0;font-size:1.6rem}.subscribe-submitted p{color:var(--muted);margin:0;line-height:1.6}@media (max-width:1100px){.subscribe-layout{grid-template-columns:280px 1fr}.subscribe-hero-col{display:none}}@media (max-width:700px){.subscribe-layout{grid-template-columns:1fr}.subscribe-info-card{position:static}}.locale-switcher{display:inline-flex;align-items:center;gap:4px;padding:4px;border-radius:999px;border:1px solid rgba(255,255,255,.14);background:rgba(9,18,31,.68);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.locale-switcher-button{min-height:34px;min-width:54px;padding:0 12px;border:0;border-radius:999px;background:transparent;color:rgba(255,255,255,.72);font-size:.8rem;font-weight:800;letter-spacing:.08em;cursor:pointer;transition:background .16s ease,color .16s ease,transform .16s ease}.locale-switcher-button:hover{color:#fff;transform:translateY(-1px)}.locale-switcher-button-active{background:rgba(232,98,10,.18);color:#fff;box-shadow:inset 0 0 0 1px rgba(232,98,10,.22)}.landing-locale-switcher{margin-right:4px}.login-card-top{display:flex;justify-content:flex-end;margin:-8px -4px}.login-locale-switcher{border-color:rgba(16,35,58,.1);background:rgba(239,244,248,.95)}.login-locale-switcher .locale-switcher-button{color:rgba(16,35,58,.58)}.login-locale-switcher .locale-switcher-button:hover{color:var(--ink)}.login-locale-switcher .locale-switcher-button-active{color:#fff}.landing-step-wrap{display:flex;align-items:flex-start;flex:1 1}@media (max-width:900px){.landing-step-wrap{flex-direction:column;align-items:center}}@media (max-width:600px){.landing-nav-actions{gap:8px}.landing-locale-switcher{margin-right:0}.locale-switcher-button{min-width:40px;padding:0 8px}}