.header-right{display:flex;align-items:center;gap:12px}.avatar{width:34px;height:34px;border-radius:50%;background:var(--accent-light);color:var(--accent);font-weight:700;font-size:14px;display:flex;align-items:center;justify-content:center;border:none;cursor:pointer;flex-shrink:0;transition:opacity .15s}.avatar:hover{opacity:.8}.avatar-menu-wrap{position:relative}@keyframes avatar-dropdown-fade-in{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.avatar-dropdown{position:absolute;top:calc(100% + 8px);right:0;background:var(--card);border:1px solid var(--border);border-radius:var(--radius);box-shadow:0 4px 20px #0000001f;min-width:240px;z-index:200;overflow:hidden;animation:avatar-dropdown-fade-in .12s ease-out}.avatar-dropdown-header{display:flex;align-items:center;gap:12px;padding:14px 16px}.avatar-dropdown-avatar{width:44px;height:44px;border-radius:50%;flex-shrink:0;overflow:hidden;background:var(--accent-light);color:var(--accent);font-weight:700;font-size:15px;display:flex;align-items:center;justify-content:center}.avatar-dropdown-identity{flex:1;min-width:0}.avatar-dropdown-name{font-weight:600;font-size:14px;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.avatar-dropdown-email{font-size:12px;color:var(--muted);margin-top:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;-webkit-user-select:text;user-select:text}.avatar-dropdown-email-primary{font-size:14px;font-weight:500;color:var(--text);margin-top:0}.avatar-dropdown-item-meta{margin-left:auto;font-size:13px;color:var(--muted)}.avatar-dropdown-item-chevron{display:inline-flex;align-items:center;color:var(--muted);margin-left:4px}.avatar-dropdown-back{font-weight:600}.avatar-dropdown-back .avatar-dropdown-icon{color:var(--text)}.avatar-dropdown-lang-row{padding-left:16px}.avatar-dropdown-lang-row.active{background:var(--accent-light);color:var(--accent);font-weight:600}.avatar-dropdown-lang-row.active:hover{background:var(--accent-light)}.avatar-dropdown-check{margin-left:auto;color:var(--accent);font-weight:700}.avatar-dropdown-divider{height:1px;background:var(--border)}.avatar-dropdown-item{display:flex;align-items:center;gap:10px;width:100%;padding:10px 16px;text-align:left;border:none;background:transparent;font-size:14px;color:var(--text);cursor:pointer;font-family:inherit}.avatar-dropdown-item:hover{background:var(--hover-bg)}.avatar-dropdown-item:focus-visible{outline:2px solid var(--accent);outline-offset:-2px}.avatar-dropdown-item.danger{color:var(--red)}.avatar-dropdown-icon{width:16px;height:16px;display:inline-flex;align-items:center;justify-content:center;color:var(--muted);flex-shrink:0}.avatar-dropdown-item.danger .avatar-dropdown-icon{color:var(--red)}.avatar-lg{width:64px;height:64px;border-radius:50%;background:var(--accent-light);color:var(--accent);font-weight:700;font-size:24px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.form-row{display:flex;gap:16px;margin-bottom:14px}.form-group{flex:1;display:flex;flex-direction:column;gap:4px}.form-group.full{flex:1 0 100%}.form-group label{font-size:13px;font-weight:600;color:var(--text)}.form-group input,.form-group select,.form-group textarea{padding:8px 12px;border:1px solid var(--border);border-radius:7px;font-size:14px;font-family:inherit;background:var(--card);color:var(--text);transition:border-color .15s,box-shadow .15s}.form-group select{appearance:none;-webkit-appearance:none;-moz-appearance:none;padding-right:32px;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 12 12' fill='none' stroke='%236b6b6b' stroke-width='1.8' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='3,5 6,8 9,5'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center;background-size:12px;cursor:pointer}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-light)}.form-group input:disabled{color:var(--muted)}.form-group textarea{resize:vertical;min-height:72px}.form-hint{font-size:11px;color:var(--muted)}.form-error{font-size:12px;color:var(--red);margin-top:4px}.form-group.invalid input,.form-group.invalid select,.form-group.invalid textarea{border-color:var(--red)}.form-group.invalid input:focus,.form-group.invalid select:focus,.form-group.invalid textarea:focus{border-color:var(--red);box-shadow:0 0 0 3px #b52a2a1f}.editable-field-label{font-size:11px;font-weight:600;color:var(--muted);text-transform:uppercase;letter-spacing:.04em;margin-bottom:3px;display:block}.editable-field-trigger{display:block;width:100%;text-align:left;background:transparent;border:1px solid transparent;padding:3px 6px;margin:-3px -6px;border-radius:4px;font:inherit;font-size:14px;color:inherit;text-decoration:inherit;cursor:text}.editable-field-trigger.is-empty{color:var(--muted)}.editable-field-trigger:hover{background:var(--accent-light);border-color:var(--border)}.editable-field-trigger:focus-visible{outline:2px solid var(--accent);outline-offset:1px}.editable-field-input{width:100%;padding:5px 8px;border:1px solid var(--accent);border-radius:4px;background:var(--card);color:var(--text);font:inherit;font-size:14px;outline:none;box-shadow:0 0 0 3px var(--accent-light)}.editable-field-hint{font-size:11px;color:var(--muted);margin-top:4px}.editable-field.inline{display:inline-block;vertical-align:baseline}.editable-field.inline .editable-field-trigger{display:inline;width:auto;padding:1px 4px;margin:-1px -4px;border-radius:3px}.editable-field.inline .editable-field-input{display:inline-block;width:auto}.chart-wrap{position:relative;height:180px;width:100%;overflow:hidden}.chart-grid-line{position:absolute;left:0;right:0;border-top:1px solid var(--border);font-size:11px;color:var(--muted);padding-left:4px}.chart-bar-group{position:absolute;bottom:0;display:flex;flex-direction:column;align-items:center;gap:2px}.chart-bar{width:28px;border-radius:4px 4px 0 0;background:var(--accent);transition:height .3s}.chart-label{font-size:10px;color:var(--muted);white-space:nowrap}.timeline{display:flex;flex-direction:column;gap:20px}.timeline-date{font-size:12px;font-weight:700;color:var(--muted);text-transform:uppercase;letter-spacing:.05em;margin-bottom:8px}.timeline-item{display:flex;align-items:flex-start;gap:12px;padding:8px 0;border-bottom:1px solid var(--border)}.timeline-item:last-child{border-bottom:none}.timeline-check{width:20px;height:20px;border-radius:4px;border:2px solid var(--border);background:transparent;flex-shrink:0;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:700;color:#fff;transition:background .15s,border-color .15s;margin-top:1px}.timeline-check:hover{border-color:var(--accent)}.timeline-check.done{background:var(--green);border-color:var(--green)}.timeline-content{flex:1;min-width:0}.timeline-desc{font-size:14px}.timeline-desc.done{text-decoration:line-through;color:var(--muted)}.section-title{font-size:13px;font-weight:700;color:var(--muted);text-transform:uppercase;letter-spacing:.04em;margin-bottom:10px}.prog-chart{display:flex;align-items:flex-end;gap:6px;height:160px;padding-bottom:24px;position:relative;border-bottom:1px solid var(--border)}.prog-bar-col{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:flex-end;height:100%;position:relative;cursor:default}.prog-bar-val{font-size:10px;color:var(--muted);margin-bottom:3px;white-space:nowrap}.prog-bar-fill{width:100%;border-radius:3px 3px 0 0;transition:height .3s}.prog-bar-fill.baseline{background:var(--border)}.prog-bar-fill.rising{background:var(--yellow)}.prog-bar-fill.lh{background:var(--accent)}.prog-bar-fill.ovulation{background:var(--green)}.prog-bar-date{position:absolute;bottom:-20px;font-size:10px;color:var(--muted);white-space:nowrap;transform:rotate(-35deg);transform-origin:top left}.print-only{display:none}@media print{@page{margin:1.2cm}html,body{background:#fff!important;color:#000!important}.app-header,.app-sidebar,.sidebar-backdrop,.modal-backdrop,.modal,.side-sheet-backdrop,.side-sheet,.toast-region,.no-print,.btn,.filter-chips,.search-input{display:none!important}.app-shell,.app-body{display:block}.app-main{padding:0;max-width:none}.card{background:transparent;border:none;box-shadow:none;padding:0;margin:0 0 18pt;page-break-inside:auto}.card-header{border-bottom:1px solid #000;margin-bottom:10pt;padding-bottom:6pt}.card-title{color:#000}table{page-break-inside:auto}tr,.litter-row,.breeding-row,.puppy-row{page-break-inside:avoid}.animal-thumb,.animal-thumb-placeholder{display:none!important}.badge,.cal-chip,.cal-cell.today,.stat-card{-webkit-print-color-adjust:exact;print-color-adjust:exact}.cal-grid{font-size:9pt}.cal-cell{min-height:70px}.cal-chip{font-size:8pt;padding:1px 4px}.print-only{display:block!important}[role=button]{cursor:default}}.photo-lightbox-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:rgba(0,0,0,.85);z-index:100;display:flex;align-items:center;justify-content:center;padding:32px}.photo-lightbox-image{max-width:100%;max-height:100%;object-fit:contain;box-shadow:0 6px 32px #0006}.photo-lightbox-close{position:absolute;top:16px;right:16px;width:36px;height:36px;border-radius:50%;border:none;background:rgba(255,255,255,.92);color:#000;font-size:18px;font-weight:600;cursor:pointer;display:flex;align-items:center;justify-content:center}.photo-lightbox-close:hover{background:#fff}.thumb-clickable{cursor:zoom-in}.thumb-clickable:focus-visible{outline:2px solid var(--accent);outline-offset:2px}@media print{.photo-lightbox-overlay{display:none!important}}.stud-card{border:1px solid var(--border);border-radius:var(--radius);padding:18px;background:var(--bg);margin-bottom:14px}.stud-name{font-weight:700;font-size:16px}.stud-meta{font-size:13px;color:var(--muted);margin-top:2px;margin-bottom:10px}.stud-tags{display:flex;gap:6px;flex-wrap:wrap;margin-bottom:10px}.stud-desc{font-size:13px;color:var(--muted)}.stud-footer{display:flex;align-items:center;justify-content:space-between;margin-top:12px}.stud-fee{font-weight:700;color:var(--text)}.compat-bar{height:6px;background:var(--border);border-radius:3px;overflow:hidden;width:80px;display:inline-block}.compat-fill{height:100%;background:var(--green);border-radius:3px}.chat-wrap{display:flex;flex-direction:column;gap:10px;max-height:300px;overflow-y:auto;padding:4px 0;margin-bottom:12px}.chat-bubble{max-width:75%;padding:8px 12px;border-radius:12px;font-size:13px;line-height:1.4}.chat-bubble.me{background:var(--text);color:#fff;align-self:flex-end;border-bottom-right-radius:3px}.chat-bubble.them{background:#f0ede8;color:var(--text);align-self:flex-start;border-bottom-left-radius:3px}.chat-ts{font-size:11px;color:var(--muted);margin-top:2px}.chat-ts.me{text-align:right}.compat-score{width:48px;height:48px;border-radius:8px;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:18px;flex-shrink:0;background:var(--border);color:var(--text)}.compat-score.high{background:var(--green-light);color:var(--green)}.compat-score.mid{background:var(--yellow-light);color:var(--yellow)}.compat-score.low{background:var(--red-light);color:var(--red)}.health-chips{display:flex;flex-wrap:wrap;gap:6px}.health-chip{display:inline-flex;align-items:center;padding:3px 9px;border-radius:6px;font-size:12px;font-weight:500;background:var(--bg);border:1px solid var(--border);color:var(--muted);white-space:nowrap}.messages{display:flex;flex-direction:column;gap:10px}.message{display:flex;flex-direction:column;max-width:75%}.message.mine{align-self:flex-end;align-items:flex-end}.message.theirs{align-self:flex-start;align-items:flex-start}.message-bubble{padding:8px 12px;border-radius:12px;font-size:13px;line-height:1.4;word-wrap:break-word}.message.mine .message-bubble{background:var(--accent);color:#fff;border-bottom-right-radius:3px}.message.theirs .message-bubble{background:var(--hover-bg);color:var(--text);border-bottom-left-radius:3px}.message-time{font-size:11px;color:var(--muted);margin-top:2px}:root{--bg: #fafaf8;--card: #ffffff;--border: #e5e3de;--text: #1a1a1a;--muted: #6b6b6b;--accent: #c8622a;--accent-light: #fdf1ea;--green: #2a7a4b;--green-light: #edf7f2;--yellow: #b58800;--yellow-light: #fffbea;--red: #b52a2a;--red-light: #fdeaea;--blue: #2a5cb5;--blue-light: #eaf0fd;--purple: #7a3cb5;--purple-light: #f3eafd;--teal: #1a7a7a;--teal-light: #e6f7f7;--agility-badge: #1e1b4b;--agility-path: rgba(139,92,246,.8);--hover-bg: #f1efe9;--radius: 10px;--shadow: 0 1px 4px rgba(0,0,0,.08)}body[data-theme=dark]{--bg: #1a1817;--card: #242120;--border: #3a3633;--text: #ededeb;--muted: #999594;--accent: #c8622a;--accent-light: #3a2a1f;--green: #5cb482;--green-light: #1c2e23;--yellow: #d4a83a;--yellow-light: #2e2814;--red: #e35454;--red-light: #2e1818;--blue: #6ea0e0;--blue-light: #1a2640;--purple: #b57de0;--purple-light: #2a1a40;--teal: #5cb4b4;--teal-light: #142e2e;--agility-badge: #7c3aed;--agility-path: rgba(167,139,250,.9);--hover-bg: #2e2a28;--shadow: 0 1px 4px rgba(0,0,0,.4);color-scheme:dark}*{box-sizing:border-box;margin:0;padding:0}button,input,select,textarea{font-family:inherit;font-size:inherit}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;background:var(--bg);color:var(--text);font-size:15px;line-height:1.5;overflow-x:hidden}.app-shell{min-height:100vh;display:flex;flex-direction:column}.app-body{display:flex;flex:1;min-height:0}.app-header{background:var(--card);border-bottom:1px solid var(--border);padding:0 20px;height:56px;display:flex;align-items:center;justify-content:space-between;position:sticky;top:0;z-index:100}.app-header .logo{display:flex;align-items:center;gap:8px;font-weight:700;font-size:17px;color:var(--text);text-decoration:none}.app-nav{background:var(--card);border-bottom:1px solid var(--border);padding:0 20px;display:flex;gap:2px;overflow-x:auto;scrollbar-width:none}.app-nav::-webkit-scrollbar{display:none}.app-nav button{background:none;border:none;border-bottom:2px solid transparent;padding:14px 14px 12px;font-size:14px;font-weight:500;color:var(--muted);cursor:pointer;white-space:nowrap;display:flex;align-items:center;gap:6px;transition:color .15s}.app-nav button:hover{color:var(--text)}.app-nav button.active{color:var(--text);border-bottom-color:var(--accent)}.nav-badge{background:var(--red);color:#fff;border-radius:10px;font-size:11px;font-weight:700;min-width:18px;height:18px;display:inline-flex;align-items:center;justify-content:center;padding:0 5px}.app-sidebar{width:220px;flex-shrink:0;background:var(--card);border-right:1px solid var(--border);display:flex;flex-direction:column;position:sticky;top:56px;height:calc(100vh - 56px);overflow-y:auto;overflow-x:hidden;transition:width .18s ease;z-index:50}.app-sidebar.collapsed{width:52px}.sidebar-nav{flex:1;padding:6px 0}.sidebar-item{display:flex;align-items:center;gap:11px;padding:10px 14px;border:none;border-left:3px solid transparent;background:transparent;color:var(--muted);cursor:pointer;width:100%;text-align:left;font-size:14px;font-weight:500;white-space:nowrap;transition:background .1s,color .1s}.sidebar-item:hover{background:var(--hover-bg);color:var(--text)}.sidebar-item.active{color:var(--accent);font-weight:700;border-left-color:var(--accent);background:var(--accent-light)}.sidebar-icon{flex-shrink:0;width:20px;height:20px;display:flex;align-items:center;justify-content:center}.sidebar-label{flex:1}.sidebar-badge{margin-left:auto;background:var(--red);color:#fff;border-radius:10px;font-size:11px;font-weight:700;padding:1px 6px;flex-shrink:0}.sidebar-footer{border-top:1px solid var(--border);padding:4px 0}.sidebar-collapse-btn{display:flex;align-items:center;gap:11px;padding:9px 14px;border:none;border-left:3px solid transparent;background:transparent;color:var(--muted);cursor:pointer;width:100%;font-size:13px;white-space:nowrap}.sidebar-collapse-btn:hover{background:var(--hover-bg);color:var(--text)}.app-main{flex:1;min-width:0;padding:24px;max-width:960px}.card{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);padding:20px;margin-bottom:20px;box-shadow:var(--shadow)}.card-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}.card-title{font-weight:700;font-size:16px}.stat-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:20px}.stat-card{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);padding:14px 16px;box-shadow:var(--shadow);display:flex;align-items:baseline;gap:8px}.stat-value{font-size:24px;font-weight:700;line-height:1;flex-shrink:0}.stat-label{font-size:13px;color:var(--muted)}.stat-card.accent .stat-value{color:var(--accent)}.stat-card.green .stat-value{color:var(--green)}.stat-card.yellow .stat-value{color:var(--yellow)}.stat-card.blue .stat-value{color:var(--blue)}.stat-card-link{cursor:pointer}.stat-card-link:hover{border-color:var(--blue);box-shadow:0 2px 8px #2a5cb51f}.badge{display:inline-flex;align-items:center;padding:2px 8px;border-radius:20px;font-size:12px;font-weight:600;white-space:nowrap}.badge-accent{background:var(--accent-light);color:var(--accent)}.badge-green{background:var(--green-light);color:var(--green)}.badge-yellow{background:var(--yellow-light);color:var(--yellow)}.badge-red{background:var(--red-light);color:var(--red)}.badge-blue{background:var(--blue-light);color:var(--blue)}.badge-purple{background:var(--purple-light);color:var(--purple)}.badge-teal{background:var(--teal-light);color:var(--teal)}.badge-muted{background:#f0ede8;color:var(--muted)}.btn{display:inline-flex;align-items:center;gap:6px;padding:8px 16px;border-radius:8px;font-size:14px;font-weight:500;cursor:pointer;border:1px solid transparent;transition:background .15s,border-color .15s}.btn-primary{background:var(--text);color:#fff;border-color:var(--text)}.btn-primary:hover{background:#333}.btn-outline{background:transparent;border-color:var(--border);color:var(--text)}.btn-outline:hover{background:var(--hover-bg)}.btn-ghost{background:transparent;border-color:transparent;color:var(--muted)}.btn-ghost:hover{background:var(--hover-bg);color:var(--text)}.btn-danger{background:var(--red);color:#fff;border-color:var(--red)}.btn-danger:hover{background:#9a2222}.btn-green{background:var(--green);color:#fff;border-color:var(--green)}.btn-green:hover{background:#1f5a37}.btn-red{background:var(--red);color:#fff;border-color:var(--red)}.btn-red:hover{background:#9a2222}.btn-blue{background:var(--blue);color:#fff;border-color:var(--blue)}.btn-blue:hover{background:#1f4690}.btn-sm{padding:5px 12px;font-size:13px}.btn-xs{padding:3px 8px;font-size:12px}.btn:focus-visible,.chip:focus-visible,.sidebar-item:focus-visible,.stat-card-link:focus-visible,.breeding-row:focus-visible,.puppy-row:focus-visible,.litter-nav-row:focus-visible,.timeline-check:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.sidebar-item:focus-visible{outline-offset:-2px}.btn-enroll:focus-visible,.courses-sort-select:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}.search-input{flex:1;padding:9px 14px 9px 38px;border:1px solid var(--border);border-radius:999px;background-color:var(--card);background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%236b6b6b' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Ccircle cx='11' cy='11' r='7'/%3E%3Cline x1='21' y1='21' x2='16.65' y2='16.65'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:12px center;background-size:16px;font-size:13px;font-family:inherit;color:var(--text);transition:border-color .15s,box-shadow .15s}.search-input::placeholder{color:var(--muted)}.search-input:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-light)}.search-input::-webkit-search-cancel-button{-webkit-appearance:none;-moz-appearance:none;appearance:none;height:14px;width:14px;background:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 12 12' fill='none' stroke='%236b6b6b' stroke-width='1.8' stroke-linecap='round'%3E%3Cline x1='3' y1='3' x2='9' y2='9'/%3E%3Cline x1='9' y1='3' x2='3' y2='9'/%3E%3C/svg%3E") no-repeat center / contain;cursor:pointer}.select-control{padding:8px 32px 8px 12px;border:1px solid var(--border);border-radius:7px;font-size:14px;font-family:inherit;color:var(--text);appearance:none;-webkit-appearance:none;-moz-appearance:none;background-color:var(--card);background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 12 12' fill='none' stroke='%236b6b6b' stroke-width='1.8' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='3,5 6,8 9,5'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center;background-size:12px;cursor:pointer;transition:border-color .15s,box-shadow .15s}.select-control:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-light)}.text-input{padding:8px 12px;border:1px solid var(--border);border-radius:7px;font-size:14px;font-family:inherit;color:var(--text);background-color:var(--card);transition:border-color .15s,box-shadow .15s}.text-input:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-light)}.text-input:disabled,.text-input[readonly]{color:var(--muted);background-color:var(--bg)}.avatar-sm{width:28px;height:28px;border-radius:50%;background:var(--accent-light);color:var(--accent);font-weight:700;font-size:11px;display:inline-flex;align-items:center;justify-content:center;overflow:hidden;flex-shrink:0;vertical-align:middle}.avatar-md{width:48px;height:48px;border-radius:50%;background:var(--accent-light);color:var(--accent);font-weight:700;font-size:18px;display:inline-flex;align-items:center;justify-content:center;overflow:hidden;flex-shrink:0}.user-cell{display:flex;align-items:center;gap:10px}.table-wrap{overflow-x:auto}.prog-list{display:flex;flex-direction:column;gap:8px}.prog-section{display:flex;flex-direction:column;gap:6px}.prog-section+.prog-section{margin-top:8px}.prog-section-header{display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap}.prog-section-label{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--muted);padding:0 2px}.prog-section-empty{font-size:13px;color:var(--muted);font-style:italic;padding:4px 0 4px 2px}.prog-item{background:var(--card);border:1px solid var(--border);border-radius:10px;overflow:hidden}.prog-item.inactive{opacity:.55}.prog-row{display:flex;align-items:center;gap:6px;min-width:0;overflow:hidden}.prog-click{display:flex;align-items:center;gap:10px;flex:1;min-width:0;padding:12px 10px;cursor:pointer;transition:background .12s;outline:none}.prog-click:hover{background:var(--hover-bg)}.prog-click:focus-visible{outline:2px solid var(--accent);outline-offset:-2px}.prog-dot{width:8px;height:8px;border-radius:50%;background:var(--border);flex-shrink:0}.prog-dot.on{background:var(--green)}.prog-info{flex:1;min-width:0}.prog-title{font-size:14px;font-weight:600;display:flex;align-items:center;flex-wrap:wrap;gap:4px;margin-bottom:2px}.prog-meta{font-size:12px;color:var(--muted)}.prog-cap{display:flex;flex-direction:column;align-items:flex-end;gap:3px;flex-shrink:0}.prog-cap .cap-bar{width:56px;flex:none}.prog-edit-icon{font-size:13px;opacity:.2;flex-shrink:0;transition:opacity .15s}.prog-click:hover .prog-edit-icon{opacity:.65}.prog-actions{display:flex;align-items:center;gap:2px;flex-shrink:0;padding:4px 0}.prog-expand.active{background:var(--hover-bg)}.prog-del{color:var(--red)!important;opacity:.45}.prog-del:hover{opacity:1}.prog-enrollees{padding:0 6px 12px;overflow-x:auto;border-top:1px solid var(--border)}.prog-enrollees-footer{padding:12px 6px 4px;border-top:1px solid var(--border);margin-top:8px}.prog-delete-confirm{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.prog-delete-confirm-text{font-size:13px;color:var(--text);flex:1;min-width:0}.cal-cell{border:none;font:inherit;text-align:left;color:inherit;cursor:default;min-width:0}.cal-cell.has-sessions{cursor:pointer}.cal-cell.has-sessions:hover:not(.out){background:var(--hover-bg)}.cal-cell:not(.has-sessions){cursor:default}button.cal-cell{cursor:pointer}button.cal-cell:hover:not(.out){background:var(--hover-bg)}.cal-cell.selected{background:var(--accent-light)}@media (max-width: 600px){.cal-cell{min-height:60px;padding:4px}.cal-chip{font-size:10px;padding:1px 3px;border-left-width:2px}.cal-chip-time{display:none}.cal-more{font-size:10px}.cal-weekday{padding:6px 2px;font-size:10px}}.cal-day-sessions{display:flex;flex-direction:column;gap:6px}.cal-day-session{display:flex;align-items:center;gap:8px;background:var(--card);border:1px solid var(--border);border-left:3px solid var(--accent);border-radius:6px;padding:8px 12px;text-align:left;font:inherit;color:inherit;cursor:pointer;transition:background .12s}.cal-day-session:hover{background:var(--hover-bg)}.cal-day-session-time{font-variant-numeric:tabular-nums;font-weight:600;font-size:13px;color:var(--accent);min-width:44px}.cal-day-session-title{font-weight:600;font-size:14px;flex:1}.cal-day-session-loc{font-size:12px;color:var(--muted)}.admin-attendees-panel{background:transparent;border-top:1px solid var(--border);padding:10px 6px 4px}.admin-attendees-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px}.admin-attendees-title{font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--muted)}.admin-attendees-empty{color:var(--muted);font-size:13px;padding:4px 0;margin:0}.admin-attendees-table{width:100%;border-collapse:collapse;font-size:13px}.admin-attendees-table th{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--muted);border-bottom:1px solid var(--border);padding:4px 8px 6px;text-align:left;white-space:nowrap}.admin-attendees-table td{padding:6px 8px;border-bottom:1px solid var(--border)}.admin-attendees-table tr:last-child td{border-bottom:none}@media (max-width: 500px){.admin-attendees-table th:nth-child(2),.admin-attendees-table td:nth-child(2),.admin-attendees-table th:nth-child(3),.admin-attendees-table td:nth-child(3){display:none}}.admin-attendees-groups{display:flex;flex-direction:column;gap:14px}.admin-attendees-group{display:flex;flex-direction:column;gap:6px}.admin-attendees-group-title{margin:0 0 4px;font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--muted)}.admin-attendees-group-dropins{border-left:3px solid var(--accent);padding-left:10px;background:color-mix(in srgb,var(--accent) 6%,transparent);border-radius:6px}.admin-attendees-group-dropins .admin-attendees-group-title{color:var(--accent)}.admin-attendees-dropin-day{display:flex;flex-direction:column}.admin-attendees-dropin-date{font-size:12px;font-weight:600;color:var(--text);padding:4px 8px;background:color-mix(in srgb,var(--accent) 10%,transparent);border-radius:4px;margin-top:6px}.admin-attendees-dropin-day:first-child .admin-attendees-dropin-date{margin-top:0}.admin-attendees-session-view{display:flex;flex-direction:column;gap:12px}.admin-attendees-session-tabs{display:flex;align-items:center;gap:10px;flex-wrap:wrap;padding-bottom:8px;border-bottom:1px solid var(--border)}.admin-attendees-session-label{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--muted)}.admin-attendees-session-pills{display:flex;gap:6px;flex-wrap:wrap}.admin-attendees-session-pill{-webkit-appearance:none;-moz-appearance:none;appearance:none;border:1px solid var(--border);background:var(--card);color:var(--text);padding:4px 10px;border-radius:999px;font:inherit;font-size:12px;font-weight:500;cursor:pointer;white-space:nowrap}.admin-attendees-session-pill:hover{border-color:var(--accent);color:var(--accent)}.admin-attendees-session-pill.is-selected{background:var(--accent);color:#fff;border-color:var(--accent)}.admin-attendees-row-dropin{background:color-mix(in srgb,var(--accent) 6%,transparent)}.admin-attendees-group-notcoming{opacity:.85}.admin-attendees-group-notcoming .admin-attendees-group-title{color:var(--muted)}.admin-dashboard{display:flex;flex-direction:column;gap:16px}.admin-dash-header{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;flex-wrap:wrap}.admin-dash-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(120px,1fr));background:var(--border);border:1px solid var(--border);border-radius:10px;overflow:hidden;gap:1px}.admin-dash-stat{background:var(--card);text-align:center;padding:10px 8px;min-width:0}.admin-dash-org{font-size:22px;font-weight:700;margin:0;line-height:1.2}.admin-dash-subtitle{font-size:13px;color:var(--muted);margin:4px 0 0}.admin-dash-alert{display:flex;align-items:center;gap:10px;width:100%;background:var(--yellow-light);border:1px solid var(--yellow);border-radius:10px;padding:10px 14px;text-align:left;cursor:pointer;color:var(--text);font:inherit}.admin-dash-alert:hover{filter:brightness(.98)}.admin-dash-alert:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.admin-dash-alert-icon{font-size:18px;line-height:1;color:var(--yellow)}.admin-dash-alert-body{flex:1;font-size:14px}.admin-dash-alert-cta{font-size:13px;font-weight:600;color:var(--yellow);white-space:nowrap}.admin-dash-range{display:inline-flex;border:1px solid var(--border);border-radius:8px;padding:2px;gap:2px;background:var(--bg)}.admin-dash-range-btn{background:none;border:none;padding:4px 10px;font-size:12px;font-weight:600;color:var(--muted);cursor:pointer;border-radius:6px}.admin-dash-range-btn.active{background:var(--card);color:var(--text);box-shadow:var(--shadow)}.admin-dash-empty{text-align:center;padding:24px 8px;color:var(--muted)}.admin-dash-empty p{margin:0 0 12px;font-size:14px}.admin-dash-sessions{display:flex;flex-direction:column;gap:6px}.admin-dash-session{display:flex;align-items:center;gap:14px;width:100%;background:none;border:1px solid transparent;border-radius:8px;padding:10px 12px;text-align:left;font:inherit;color:var(--text);cursor:pointer;transition:background .12s,border-color .12s}.admin-dash-session:hover{background:var(--hover-bg);border-color:var(--border)}.admin-dash-session:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.admin-dash-session.today{background:var(--accent-light);border-color:var(--accent)}.admin-dash-session.today:hover{background:var(--accent-light);filter:brightness(.97)}.admin-dash-session-date{display:flex;flex-direction:column;align-items:flex-start;min-width:96px}.admin-dash-session-day{font-size:13px;font-weight:600;color:var(--text)}.admin-dash-session-day-pill{display:inline-block;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.04em;color:var(--accent);margin-top:2px}.admin-dash-session-time{font-size:12px;color:var(--muted);margin-top:2px}.admin-dash-session-body{flex:1;min-width:0}.admin-dash-session-title{font-weight:600;font-size:14px}.admin-dash-session-meta{display:flex;gap:10px;font-size:12px;color:var(--muted);margin-top:2px;flex-wrap:wrap}.admin-dash-session-cap{display:flex;flex-direction:column;align-items:flex-end;min-width:96px;gap:4px}.admin-dash-cap-label{font-size:13px;font-weight:600;color:var(--text)}.admin-dash-cap-label.full{color:var(--red)}.admin-dash-cap-label.near{color:var(--yellow)}.admin-dash-cap-bar{width:80px;height:6px;background:var(--border);border-radius:3px;overflow:hidden}.admin-dash-cap-fill{height:100%;background:var(--green);transition:width .2s ease}.admin-dash-cap-fill.near{background:var(--yellow)}.admin-dash-cap-fill.full{background:var(--red)}.admin-dash-more{text-align:center;font-size:12px;color:var(--muted);padding:6px 0 2px}.admin-dash-notices{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:12px}.admin-dash-notice{display:inline-flex;align-items:center;gap:6px;padding:5px 12px;border-radius:20px;border:1px solid var(--border);background:var(--card);color:var(--text);font-size:13px;cursor:pointer;transition:background .15s}.admin-dash-notice:hover{background:var(--hover-bg)}.admin-dash-notice--warn{background:var(--yellow-light);border-color:var(--yellow)}.admin-dash-notice--warn:hover{filter:brightness(.97)}@media (max-width: 540px){.admin-dash-session{flex-wrap:wrap;gap:8px}.admin-dash-session-date{min-width:0;flex-basis:100%;flex-direction:row;align-items:center;gap:8px}.admin-dash-session-cap{min-width:0;flex-basis:100%;flex-direction:row;justify-content:space-between}.admin-dash-cap-bar{flex:1;max-width:160px}}.admin-dash-transfer-row{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:8px 0;border-bottom:1px solid var(--border)}.admin-dash-transfer-row:last-child{border-bottom:none}.admin-dash-transfer-info{display:flex;flex-direction:column;gap:2px;min-width:0;flex:1}.admin-dash-transfer-names{font-weight:600;font-size:14px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.admin-dash-transfer-course{font-size:12px;color:var(--muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.admin-transfer-confirm{display:flex;align-items:center;gap:8px;font-size:13px;color:var(--muted)}.admin-transfer-confirm-text{font-weight:500}.team-section-heading{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--muted);margin:20px 0 8px}.team-section-heading:first-of-type{margin-top:4px}.team-list{display:flex;flex-direction:column}.team-row{display:flex;align-items:center;gap:12px;border-bottom:1px solid var(--border);border-left:3px solid transparent;padding:10px 4px 10px 8px;flex-wrap:wrap}.team-row.is-self{border-left-color:var(--accent);background:var(--accent-light)}.team-row-main{display:flex;align-items:center;gap:10px;flex:1;min-width:0}.team-row-text{min-width:0;flex:1}.team-row-name{font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.team-row-self-tag{color:var(--muted);font-weight:400}.team-row-email{font-size:12px;color:var(--muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.team-row-role-select{width:110px;flex-shrink:0}.team-row-actions{display:flex;gap:6px;flex-shrink:0}.team-confirm-bar{display:flex;align-items:center;gap:8px;flex:1 1 100%;padding:8px 10px;margin-top:6px;background:var(--yellow-light, #fffbea);border-left:3px solid var(--yellow, #b58800);border-radius:4px;font-size:13px}.team-confirm-bar-text{flex:1;color:var(--text)}.team-invite-form .form-row{gap:8px}.team-share-panel{margin-top:12px;padding:12px;background:var(--bg);border:1px solid var(--border);border-radius:8px}.team-share-panel-msg{font-size:13px;margin:0 0 8px}.team-share-row{display:flex;gap:6px;align-items:stretch}.team-share-row input{flex:1;min-width:0;font-size:12px;font-family:ui-monospace,SFMono-Regular,Menlo,monospace}@media (max-width: 600px){.team-invite-form .form-row{flex-direction:column;align-items:stretch}.team-invite-form .form-group{width:100%}.team-row{padding:12px 8px}.team-row-role-select{width:100%}.team-row-actions{width:100%;justify-content:flex-end}}.admin-xfer-tabs{display:flex;gap:2px;border-bottom:1px solid var(--border);margin:0 -20px 16px;padding:0 20px}.admin-xfer-tab{display:flex;align-items:center;gap:6px;padding:8px 14px;font:inherit;font-size:13px;font-weight:500;color:var(--muted);background:none;border:none;border-bottom:2px solid transparent;margin-bottom:-1px;cursor:pointer;transition:color .12s,border-color .12s;border-radius:0;white-space:nowrap}.admin-xfer-tab:hover{color:var(--text)}.admin-xfer-tab.active{color:var(--accent);border-bottom-color:var(--accent)}.admin-xfer-tab-badge{display:inline-flex;align-items:center;justify-content:center;min-width:18px;height:18px;padding:0 5px;border-radius:999px;font-size:11px;font-weight:700;background:var(--accent);color:#fff;line-height:1}.admin-xfer-tab-count{font-size:11px;font-weight:500;color:var(--muted);margin-left:2px}.admin-xfer-tab.active .admin-xfer-tab-count{color:var(--accent)}.admin-xfer-window-top{margin-bottom:12px}.admin-xfer-panel{min-height:60px}.admin-xfer-empty{color:var(--muted);font-size:14px;padding:4px 0;margin:0}.admin-xfer-window{display:inline-flex;gap:0;margin-bottom:12px;background:var(--bg);border:1px solid var(--border);border-radius:8px;padding:2px}.admin-xfer-window-opt{font:inherit;font-size:12px;font-weight:500;color:var(--muted);background:none;border:none;padding:4px 10px;border-radius:6px;cursor:pointer;transition:background .12s,color .12s}.admin-xfer-window-opt:hover{color:var(--text)}.admin-xfer-window-opt.active{background:var(--card);color:var(--text);box-shadow:0 1px 2px #0000000f}table{width:100%;border-collapse:collapse;font-size:14px}th{text-align:left;font-size:12px;font-weight:600;color:var(--muted);text-transform:uppercase;letter-spacing:.04em;padding:8px 12px;border-bottom:1px solid var(--border)}td{padding:10px 12px;border-bottom:1px solid var(--border);vertical-align:middle}tr:last-child td{border-bottom:none}tr:hover td{background:var(--hover-bg)}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:rgba(0,0,0,.45);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:200;padding:16px}.modal{background:var(--card);border-radius:var(--radius);padding:24px;max-width:520px;width:100%;box-shadow:0 8px 40px #0000002e;display:flex;flex-direction:column;max-height:calc(100vh - 32px)}.modal-lg{max-width:680px}@media (max-width: 600px){.modal-backdrop-sheet{align-items:flex-end;padding:0}.modal-sheet{max-width:100%;width:100%;height:calc(100vh - 56px);max-height:calc(100vh - 56px);border-radius:var(--radius) var(--radius) 0 0;margin:0}}.modal-body{overflow-y:auto;flex:1;min-height:0}.modal-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px}.modal-title{font-weight:700;font-size:17px}.modal-close{background:none;border:none;font-size:20px;cursor:pointer;color:var(--muted);line-height:1}.modal-footer{display:flex;justify-content:flex-end;gap:10px;margin-top:20px}.side-sheet-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:rgba(0,0,0,.4);z-index:200;display:flex;justify-content:flex-end}.side-sheet{background:var(--card);width:100%;max-width:520px;height:100vh;display:flex;flex-direction:column;box-shadow:-8px 0 40px #0000002e;animation:side-sheet-in .18s ease-out}@keyframes side-sheet-in{0%{transform:translate(100%)}to{transform:translate(0)}}.side-sheet-header{display:flex;align-items:flex-start;gap:12px;padding:20px 24px 14px;border-bottom:1px solid var(--border)}.side-sheet-title{font-weight:700;font-size:17px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.side-sheet-subtitle{font-size:12px;color:var(--muted);margin-top:3px}.side-sheet-body{flex:1;min-height:0;overflow-y:auto;padding:20px 24px 24px}@media (max-width: 600px){.side-sheet{max-width:100%}}.breeding-row{background:var(--card);transition:background .12s}.breeding-row:hover{background:var(--bg)}.breeding-row .breeding-delete{opacity:0;transition:opacity .12s}.breeding-row:hover .breeding-delete,.breeding-row:focus-within .breeding-delete{opacity:1}@media (hover: none){.breeding-row .breeding-delete{opacity:1}}.filter-chips{display:flex;gap:8px;margin-bottom:16px;flex-wrap:wrap}.chip{padding:5px 14px;border-radius:20px;font-size:13px;border:1px solid var(--border);background:transparent;color:var(--muted);cursor:pointer}.chip.active{background:var(--text);color:#fff;border-color:var(--text)}.alert{padding:12px 16px;border-radius:var(--radius);font-size:14px;margin-bottom:16px;display:flex;align-items:center;gap:10px}.alert-yellow{background:var(--yellow-light);color:var(--yellow);border:1px solid #f5d97a}.alert-green{background:var(--green-light);color:var(--green);border:1px solid #9fd4b4}.alert-red{background:var(--red-light);color:var(--red);border:1px solid #f5a0a0}.alert-blue{background:var(--blue-light);color:var(--blue);border:1px solid #a0b8f5}.alert-clickable{cursor:pointer}.alert-clickable:hover{filter:brightness(.97)}.alert-arrow{margin-left:auto;font-size:16px;flex-shrink:0}.empty-icon{font-size:40px;margin-bottom:12px}.pill-tabs{display:flex;gap:6px;margin-bottom:20px;flex-wrap:wrap}.pill-tab{padding:6px 16px;border-radius:20px;font-size:13px;font-weight:500;border:1px solid var(--border);background:transparent;color:var(--muted);cursor:pointer;transition:background .15s}.pill-tab.active{background:var(--text);color:#fff;border-color:var(--text)}.login-screen{min-height:100vh;display:flex;align-items:center;justify-content:center;background:var(--bg);padding:20px}.login-card{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);padding:40px;max-width:380px;width:100%;box-shadow:var(--shadow);text-align:center}.paw{font-size:48px;margin-bottom:16px}.login-card h1{font-size:24px;font-weight:700;margin-bottom:8px}.login-card .subtitle{color:var(--muted);font-size:14px;margin-bottom:24px}.divider{display:flex;align-items:center;color:var(--muted);font-size:13px;margin:16px 0;gap:10px}.divider:before,.divider:after{content:"";flex:1;border-top:1px solid var(--border)}.app-shell.landing{display:flex;flex-direction:column;min-height:100vh}.hero{text-align:center;padding:56px 24px 32px}.hero h1{font-size:36px;font-weight:800;margin-bottom:12px}.hero p{font-size:16px;color:var(--muted);max-width:520px;margin:0 auto;line-height:1.6}.portal-grid{display:grid;gap:24px;padding:0 24px 48px;max-width:900px;margin:0 auto;width:100%}@media (min-width: 600px){.portal-grid{grid-template-columns:repeat(2,1fr)}}.portal-card{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);padding:28px;display:flex;flex-direction:column;gap:12px;box-shadow:var(--shadow);transition:box-shadow .15s,border-color .15s,transform .08s;cursor:pointer;-webkit-tap-highlight-color:transparent}.portal-card:hover{box-shadow:0 4px 20px #0000001a;border-color:var(--accent)}.portal-card:active{transform:scale(.99)}.portal-card:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.portal-icon{font-size:40px;line-height:1}.portal-label{font-size:12px;font-weight:600;color:var(--muted);text-transform:uppercase;letter-spacing:.06em}.portal-title{font-size:20px;font-weight:700;margin-top:2px}.portal-desc{font-size:14px;color:var(--muted);line-height:1.55}.portal-grid--compact{gap:12px;max-width:720px}@media (min-width: 480px){.portal-grid--compact{grid-template-columns:repeat(3,1fr)}}@media (min-width: 720px){.portal-grid--compact{grid-template-columns:repeat(4,1fr)}}.portal-grid--compact .portal-card{padding:14px 10px 12px;gap:6px;align-items:center;text-align:center}.portal-grid--compact .portal-icon{font-size:36px}.portal-grid--compact .portal-label,.portal-grid--compact .portal-desc,.portal-grid--compact .portal-features,.portal-grid--compact .portal-public-badge{display:none}.portal-grid--compact .portal-title{font-size:13px;font-weight:600;margin:0;line-height:1.25}.portal-grid--compact .btn-portal{margin-top:4px;padding:0;width:28px;height:4px;border-radius:2px;align-self:center;font-size:0;color:transparent;overflow:hidden}.portal-grid--large{gap:28px}.portal-grid--large .portal-card{padding:36px;gap:16px}.portal-grid--large .portal-icon{font-size:56px}.portal-grid--large .portal-title{font-size:24px}.portal-grid--large .portal-desc{font-size:15px}.header-icon-btn{width:44px;height:44px;border-radius:6px;background:transparent;border:1px solid var(--border);color:var(--text);display:inline-flex;align-items:center;justify-content:center;cursor:pointer;padding:0;flex-shrink:0;transition:background .15s,border-color .15s}.header-icon-btn svg{width:20px;height:20px}.header-icon-btn:hover{background:var(--hover-bg, rgba(0,0,0,.04));border-color:var(--accent)}.header-icon-btn:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.header-icon-btn[aria-expanded=true]{background:var(--accent-light, rgba(0,0,0,.06));border-color:var(--accent)}.portal-features{list-style:none;display:flex;flex-direction:column;gap:5px;margin:0;padding:0}.portal-features li{font-size:13px;color:var(--muted);padding-left:16px;position:relative}.portal-features li:before{content:"✓";position:absolute;left:0;color:var(--green);font-size:12px}.btn-portal{margin-top:auto;padding:10px 18px;border:none;border-radius:8px;color:#fff;font-size:14px;font-weight:600;cursor:pointer;transition:filter .15s;align-self:flex-start}.btn-portal:hover{filter:brightness(.9)}.btn-portal:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.portal-public-badge{display:inline-block;font-size:11px;font-weight:600;color:var(--green);background:var(--green-light);border-radius:20px;padding:2px 10px;align-self:flex-start}.courses-hero{background:linear-gradient(135deg,#1a5535 0%,#2a7a4b 60%,#3a9a5f 100%);color:#fff;padding:52px 24px 44px;text-align:center}.courses-hero h1{font-size:32px;font-weight:800;margin-bottom:10px;letter-spacing:-.02em}.courses-hero p{font-size:16px;opacity:.85;max-width:480px;margin:0 auto 28px}.courses-search-bar{display:flex;gap:8px;max-width:580px;margin:0 auto;flex-wrap:wrap}.courses-search-input{flex:1;min-width:160px;padding:11px 14px;border-radius:8px;border:none;font-size:14px;outline:none;background:white;color:var(--text);font-family:inherit}.courses-search-input::placeholder{color:var(--muted)}.app-main .courses-hero{margin:-24px -24px 0}.app-main .courses-stats-bar{margin:0 -24px}.courses-stats-bar{background:#2a7a4b;border-bottom:1px solid rgba(255,255,255,.15);padding:10px 24px;display:flex;gap:24px;flex-wrap:wrap;justify-content:center}.courses-stats-bar span{font-size:13px;color:#ffffffd9}.courses-stats-bar strong{color:#fff;font-weight:700}.courses-filters{display:flex;align-items:center;gap:8px;flex-wrap:wrap;margin-bottom:20px}.courses-filters-label{font-size:13px;font-weight:600;color:var(--muted);flex-shrink:0}.courses-pill{display:inline-flex;align-items:center;gap:5px;padding:6px 14px;border-radius:20px;font-size:13px;font-weight:500;border:1px solid var(--border);background:var(--card);cursor:pointer;color:var(--muted);transition:all .15s;white-space:nowrap}.courses-pill.active{background:var(--green);border-color:var(--green);color:#fff}.courses-pill:hover:not(.active){background:var(--green-light);border-color:var(--green);color:var(--green)}.courses-pill-count{font-size:11px;opacity:.75;font-weight:600}.courses-filters-right{margin-left:auto;display:flex;align-items:center;gap:10px;flex-wrap:wrap}.courses-distance-row{display:flex;align-items:center;gap:8px;flex-wrap:wrap;margin:-12px 0 20px}.courses-pill-ghost{background:transparent}.courses-distance-error{font-size:12px;color:var(--red)}.user-location-marker{background:transparent;border:none}.user-location-dot{width:14px;height:14px;border-radius:50%;background:#3b82f6;border:3px solid #fff;box-shadow:0 0 0 2px #3b82f666,0 1px 4px #0000004d}.courses-avail-toggle{display:flex;align-items:center;gap:6px;font-size:13px;color:var(--muted);cursor:pointer}.courses-avail-toggle input{accent-color:var(--green);width:14px;height:14px;cursor:pointer}.courses-sort-select{padding:6px 10px;border:1px solid var(--border);border-radius:7px;font-size:13px;background:var(--card);color:var(--text);cursor:pointer;outline:none;font-family:inherit}.courses-results-header{font-size:14px;color:var(--muted);margin-bottom:14px;display:flex;align-items:center;justify-content:space-between;gap:8px}.courses-subview-toggle{display:flex;border:1px solid var(--border);border-radius:6px;overflow:hidden;flex-shrink:0}.courses-subview-btn{padding:3px 10px;font-size:14px;background:var(--card);border:none;cursor:pointer;color:var(--muted);line-height:1}.courses-subview-btn.active{background:var(--accent);color:#fff}.courses-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:14px}.course-card{background:var(--card);border:1px solid var(--border);border-radius:12px;padding:16px;box-shadow:var(--shadow);display:flex;flex-direction:column;gap:0;transition:box-shadow .2s,transform .15s}.course-card:hover{box-shadow:0 4px 20px #0000001a;transform:translateY(-1px)}.course-card-top{display:flex;align-items:flex-start;justify-content:space-between;gap:10px;margin-bottom:12px}.course-disc-tag{display:inline-flex;align-items:center;padding:3px 9px;border-radius:20px;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.05em;margin-bottom:6px}.disc-obedience{background:var(--green-light);color:var(--green)}.disc-agility{background:var(--blue-light);color:var(--blue)}.disc-rally{background:var(--accent-light);color:var(--accent)}.disc-nose-work{background:var(--purple-light);color:var(--purple)}.disc-other{background:var(--yellow-light);color:var(--yellow)}.course-name{font-size:18px;font-weight:700;margin-bottom:3px;line-height:1.3}.course-organizer{font-size:12px;color:var(--muted)}.course-price{text-align:right;flex-shrink:0}.course-price-amount{font-size:20px;font-weight:800;line-height:1;color:var(--green)}.course-meta-bar{display:flex;flex-wrap:wrap;gap:4px 14px;margin-bottom:10px;font-size:13px;color:var(--muted)}.course-meta-item{display:inline-flex;align-items:center;gap:4px;white-space:nowrap}.course-meta-icon{font-size:13px;flex-shrink:0}.cap-row{margin-bottom:10px}.cap-bar-wrap{display:flex;align-items:center;gap:8px}.cap-bar{flex:1;height:4px;background:var(--border);border-radius:2px;overflow:hidden}.cap-fill{height:100%;border-radius:2px;background:var(--green);transition:width .3s}.cap-fill.near{background:var(--yellow)}.cap-fill.full{background:var(--red)}.cap-count{font-size:11px;color:var(--muted);flex-shrink:0}.cap-count.full{color:var(--red);font-weight:600}.cap-count.near{color:var(--yellow);font-weight:600}.course-desc{font-size:13px;color:var(--muted);margin-bottom:12px;line-height:1.5;flex:1;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.course-footer{margin-top:auto}.course-my-enrollments{margin:10px 0 8px}.course-my-enrollments-label{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--muted);margin-bottom:6px}.course-my-enrollments-list{display:flex;flex-direction:column;gap:4px}.course-my-enrollment-row{display:flex;align-items:center;gap:8px;padding:8px 10px;background:var(--bg);border:1px solid var(--border);border-radius:8px;font:inherit;color:inherit;text-align:left;cursor:pointer;transition:background .12s,border-color .12s}.course-my-enrollment-row:hover{background:var(--hover-bg);border-color:var(--accent)}.course-my-enrollment-row:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.course-my-enrollment-dog{font-weight:600;font-size:13px;flex-shrink:0}.course-my-enrollment-tag{flex:1;font-size:12px;color:var(--muted);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.course-my-enrollment-tag-dropin{color:var(--accent);font-weight:600}.course-my-enrollment-arrow{color:var(--muted);flex-shrink:0;font-size:14px}.course-my-enrollment-row:hover .course-my-enrollment-arrow{color:var(--accent)}.btn-enroll{width:100%;padding:10px;border-radius:8px;font-size:14px;font-weight:600;cursor:not-allowed;border:none;text-align:center;transition:opacity .15s;font-family:inherit}.btn-enroll.available{background:var(--green);color:#fff;opacity:.85;cursor:pointer}.btn-enroll.available:hover{opacity:1}.btn-enroll.full{background:var(--bg);border:1px solid var(--border);color:var(--muted)}.btn-enroll.coming-soon{background:var(--muted)!important;border-color:var(--muted)!important;opacity:.65;cursor:not-allowed}.btn-enroll.enrolled{background:var(--green-light, #d1fae5);color:var(--green);border:1px solid var(--green);cursor:default}.course-waitlist-note,.course-enrol-note{font-size:11px;color:var(--muted);margin-top:4px;text-align:center}.course-enrol-mine{color:var(--green);font-weight:500}.map-popup-enrol{margin-top:8px;width:100%;padding:6px;border:none;border-radius:4px;background:var(--green);color:#fff;font-size:12px;font-weight:600;cursor:pointer}.enrol-modal-course-name{font-size:13px;color:var(--muted);margin:-8px 0 20px}.enrol-modal-error{font-size:13px;color:var(--red);margin-top:-4px}.enrol-dog-pick{margin-top:4px}.course-detail-modal{display:flex;flex-direction:column;gap:16px}.course-detail-tags{display:flex;align-items:center;gap:10px;flex-wrap:wrap}.course-detail-organizer{font-size:13px;color:var(--muted)}.course-detail-price{font-size:20px;font-weight:600;color:var(--text)}.course-detail-section{display:flex;flex-direction:column;gap:6px;padding-top:12px;border-top:1px solid var(--border)}.course-detail-section-title{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--muted);margin:0}.course-detail-location{font-size:14px}.course-detail-address{font-size:13px;color:var(--muted);white-space:pre-line}.course-detail-schedule-summary{font-size:14px}.course-detail-next{font-size:13px;color:var(--muted)}.course-detail-sessions{list-style:none;padding:0;margin:4px 0 0;display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:6px 12px}.course-detail-sessions li{display:flex;gap:8px;font-size:13px}.course-detail-sessions.course-detail-sessions-enrolled{grid-template-columns:1fr}.course-detail-session-row{display:flex;align-items:center;gap:8px}.course-session-actions{margin-left:auto;display:inline-flex;align-items:center;gap:2px;flex-shrink:0}.course-session-cant-btn{color:var(--muted)!important;display:inline-flex;align-items:center}.course-session-cant-btn:hover{color:var(--red)!important;border-color:var(--red)!important}.course-session-attend-btn{color:var(--muted)!important;display:inline-flex;align-items:center}.course-session-attend-btn:hover,.course-session-attend-btn.confirmed{color:var(--green)!important;border-color:var(--green)!important}.course-session-cancel-offer-btn{color:var(--accent)!important;display:inline-flex;align-items:center;opacity:.7}.course-session-cancel-offer-btn:hover{color:var(--red)!important;border-color:var(--red)!important;opacity:1}.course-detail-session-time{color:var(--muted)}.session-offer-date{font-size:14px;font-weight:500;margin-bottom:14px;padding:8px 12px;background:var(--hover-bg);border-radius:8px;display:flex;align-items:center;gap:6px;flex-wrap:wrap}.course-detail-description{margin:0;font-size:14px;line-height:1.55;white-space:pre-line}.course-detail-capacity{font-size:14px}.course-detail-enrollment-row{display:flex;gap:8px;font-size:14px}.course-detail-enrollment-label{font-weight:600;min-width:90px;color:var(--muted)}.course-detail-enrollment-single{border-left:3px solid var(--accent);padding-left:12px}.course-detail-single-session-badge{display:inline-flex;align-items:center;gap:6px;padding:4px 10px;margin-bottom:8px;background:color-mix(in srgb,var(--accent) 14%,transparent);color:var(--accent);border-radius:999px;font-size:13px;font-weight:600}.course-single-session-tag{background:color-mix(in srgb,var(--accent) 12%,transparent);color:var(--accent);border-radius:999px;padding:2px 8px;font-weight:600}.form-section-label{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--muted);margin-bottom:12px}.form-section-divider{border:none;border-top:1px solid var(--border);margin:16px 0}@media (max-width: 600px){.modal-overlay{align-items:flex-end!important;padding:0!important}.modal-panel{max-width:100%!important;max-height:96vh!important;border-radius:16px 16px 0 0!important;padding:16px 16px 0!important}}.modal-discard-bar{display:flex;align-items:center;gap:10px;background:var(--yellow-light);border:1px solid var(--yellow);border-radius:8px;padding:10px 14px;margin-bottom:16px;font-size:13px;flex-wrap:wrap}.modal-discard-bar span{flex:1;color:var(--text)}.course-schedule-editor{border:1px solid var(--border);border-radius:8px;padding:16px;margin-bottom:12px;display:flex;flex-direction:column;gap:12px}.schedule-weekday-row{display:flex;gap:6px;flex-wrap:wrap}.schedule-weekday-btn{display:inline-flex;align-items:center;justify-content:center;width:40px;height:36px;border:1px solid var(--border);border-radius:6px;font-size:13px;font-weight:500;cursor:pointer;color:var(--muted);-webkit-user-select:none;user-select:none}.schedule-weekday-btn.active{background:var(--accent);color:#fff;border-color:var(--accent)}.schedule-date-list{display:flex;flex-direction:column;gap:6px;margin-bottom:8px}.schedule-date-item{display:flex;align-items:center;gap:6px}.schedule-date-item input[type=date]{flex:1}.schedule-help-text{font-size:12px;color:var(--muted);margin:-4px 0 6px}.bulk-date-import{margin-top:10px;border-top:1px dashed var(--border);padding-top:10px;display:flex;flex-direction:column;gap:6px}.bulk-date-textarea{width:100%;padding:8px 10px;border:1px solid var(--border);border-radius:7px;font-size:13px;font-family:inherit;background:var(--card);color:var(--text);resize:vertical;box-sizing:border-box}.bulk-date-textarea:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-light)}.bulk-date-textarea::placeholder{color:var(--muted)}.bulk-date-footer{display:flex;align-items:center;justify-content:space-between;gap:8px}.courses-cta-banner{background:var(--green-light);border:1px solid #b0ddc0;border-radius:12px;padding:24px;text-align:center;margin-top:32px;margin-bottom:16px}.courses-cta-banner h3{font-size:18px;font-weight:700;margin-bottom:6px;color:var(--green)}.courses-cta-banner p{font-size:14px;color:var(--muted)}.courses-my-header{padding:12px 24px 8px}.courses-my-header h2{font-size:20px;color:var(--text);margin:0;display:flex;align-items:baseline;gap:10px;flex-wrap:wrap}.courses-my-subtitle{font-size:13px;font-weight:400;color:var(--muted)}.course-calendar{padding:0 4px}.course-session-list{display:flex;flex-direction:column;gap:8px}.course-session-row{display:flex;gap:16px;align-items:flex-start;padding:12px 16px;background:var(--card);border:1px solid var(--border);border-radius:10px}.course-session-date{min-width:80px;text-align:right}.course-session-day{font-size:13px;font-weight:600;color:var(--text)}.course-session-time{font-size:12px;color:var(--muted);margin-top:2px}.course-session-info{flex:1;min-width:0}.course-session-title{font-size:15px;font-weight:600;color:var(--text);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.course-session-meta{font-size:12px;color:var(--muted);margin-top:2px}.course-session-dog{color:var(--accent)}.courses-map-wrap{border-radius:12px;overflow:hidden;border:1px solid var(--border);margin-bottom:24px}.courses-map{height:520px;width:100%}.courses-map-geocoding{font-size:12px;color:var(--muted);padding:6px 12px;background:var(--bg);border-bottom:1px solid var(--border)}.map-popup{min-width:200px}.map-popup-title{font-weight:700;font-size:14px;margin-bottom:2px}.map-popup-org{font-size:12px;color:#666;margin-bottom:8px}.map-popup-meta{display:flex;flex-direction:column;gap:3px;font-size:12px}@media (max-width: 640px){.courses-hero h1{font-size:24px}.courses-hero{padding:36px 16px 32px}.courses-grid{grid-template-columns:1fr}.courses-filters-right{margin-left:0;width:100%}.courses-stats-bar{gap:14px;padding:10px 16px;justify-content:flex-start}.courses-map{height:340px}.app-main .courses-hero{margin:-16px -14px 0}.app-main .courses-stats-bar{margin:0 -14px}}@media (max-width: 480px){.courses-search-bar{flex-direction:column}.courses-search-input{min-width:0;width:100%}.courses-stats-bar{font-size:12px;gap:8px}}.logo-back-btn{background:none;border:none;cursor:pointer;font:inherit;padding:4px 8px;border-radius:6px;transition:background .15s}.logo-back-btn:hover{background:var(--hover-bg)}.logo-back-btn:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.course-footer-actions{display:flex;flex-direction:column;gap:6px}.course-enrolled-bar{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.course-enrol-badge{font-size:12px;font-weight:600;color:var(--green);flex:1}.btn-enroll.btn-sm{padding:6px 12px;font-size:12px;width:auto}.btn-details{width:100%;padding:6px;border-radius:6px;font-size:13px;font-weight:500;cursor:pointer;border:1px solid var(--border);background:transparent;color:var(--muted);transition:all .15s;font-family:inherit}.btn-details:hover{border-color:var(--accent);color:var(--accent);background:var(--accent-light)}.course-desc-expanded{-webkit-line-clamp:unset!important;overflow:visible!important}.course-desc-more{background:none;border:none;padding:0 0 8px;font-size:12px;color:var(--accent);cursor:pointer;font-family:inherit;text-decoration:underline}.courses-filters-bar{padding:0 24px;margin-bottom:4px;display:none}.courses-filters-toggle{background:none;border:1px solid var(--border);border-radius:20px;padding:5px 14px;font-size:13px;font-weight:500;color:var(--muted);cursor:pointer;font-family:inherit;display:inline-flex;align-items:center;gap:6px}.courses-filters-toggle:hover{border-color:var(--accent);color:var(--accent)}.courses-filters-toggle-arrow{font-size:10px}.courses-filters-active-dot{width:7px;height:7px;border-radius:50%;background:var(--accent);display:inline-block;flex-shrink:0}@media (max-width: 640px){.courses-filters-bar{display:block}}.courses-filters-sep{width:100%;height:1px;background:var(--border);margin:4px 0}.courses-filter-location-wrap{margin-top:4px}.courses-distance-prompt{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.courses-distance-hint{font-size:12px;color:var(--muted)}.courses-distance-retry{background:none;border:none;padding:0;font-size:12px;color:var(--accent);cursor:pointer;font-family:inherit;text-decoration:underline}.courses-geocoding-notice{font-size:13px;color:var(--muted);padding:6px 0 10px}.courses-toast{position:fixed;bottom:24px;left:50%;transform:translate(-50%);background:#1a1a1a;color:#fff;padding:10px 20px;border-radius:8px;font-size:14px;font-weight:500;z-index:9999;box-shadow:0 4px 20px #00000040;pointer-events:none;white-space:nowrap}body[data-theme=dark] .courses-toast{background:#ededeb;color:#1a1a1a}.map-popup-details{margin-top:8px;width:100%;padding:5px;border:1px solid var(--border, #ccc);border-radius:4px;background:transparent;color:var(--accent, #c8622a);font-size:12px;font-weight:600;cursor:pointer}.map-popup-details:hover{background:var(--accent-light, #fdf1ea)}.courses-map-unmapped{font-size:12px;color:var(--muted);padding:8px 12px;border-top:1px solid var(--border);background:var(--bg)}.courses-map-unmapped>summary{cursor:pointer}.courses-map-unmapped-list{margin:6px 0 0 16px;padding:0;list-style:disc;display:flex;flex-direction:column;gap:3px}.courses-map-unmapped-loc{color:var(--muted)}.empty-state-hint{font-size:13px;color:var(--muted);margin-top:-8px}.course-slot-card{position:relative}.course-slot-badge{display:inline-block;font-size:11px;font-weight:600;letter-spacing:.03em;text-transform:uppercase;background:var(--green-light);color:var(--green);border:1px solid var(--green);border-radius:4px;padding:2px 7px;margin-bottom:10px}.course-slot-note{font-size:13px;color:var(--muted);font-style:italic;margin:8px 0;padding:6px 10px;border-left:3px solid var(--border);background:var(--hover-bg);border-radius:0 4px 4px 0}.course-slot-offered{font-size:12px;color:var(--muted);margin-bottom:6px}.courses-slots-header{padding:12px 16px 0}.courses-slots-header h2{margin:0 0 4px;font-size:18px}.courses-slots-subtitle{font-size:13px;color:var(--muted);margin:0 0 4px}.transfer-enrolled-dog{font-size:13px;color:var(--muted);margin:-8px 0 14px}.transfer-intro{font-size:13px;color:var(--muted);margin-bottom:16px;line-height:1.5}.course-detail-transfer-btn{margin-top:10px;align-self:flex-start}.danger-zone{border-color:var(--red)!important;background:var(--red-light)!important}.danger-title{font-weight:700;color:var(--red);margin-bottom:16px;font-size:15px}.danger-row{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:14px 0;border-top:1px solid #f5a0a0}.danger-row:first-of-type{border-top:none}.danger-row-label{font-weight:600;font-size:14px}.danger-row-desc{font-size:13px;color:var(--muted);margin-top:2px}@media (max-width: 600px){.app-main{padding:16px 14px}.stat-grid{grid-template-columns:repeat(2,1fr);gap:10px}.form-row{flex-direction:column;gap:10px}.modal{padding:18px}.hide-mobile{display:none!important}.app-sidebar{position:fixed;top:56px;left:0;width:220px!important;height:calc(100vh - 56px);transform:translate(-100%);transition:transform .2s ease,box-shadow .2s ease;z-index:150}.app-sidebar.mobile-open{transform:translate(0);box-shadow:4px 0 24px #0000002e}}.sidebar-backdrop{display:none;position:fixed;right:0;bottom:0;left:0;top:56px;background:rgba(0,0,0,.28);-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);z-index:149}@media (max-width: 600px){.sidebar-backdrop{display:block}}@media (min-width: 601px){.hide-desktop{display:none!important}}.animal-detail-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:16px 28px}@media (max-width: 600px){.animal-detail-grid{grid-template-columns:1fr}}.action-item{display:flex;align-items:flex-start;justify-content:space-between;gap:8px;padding:11px 0;border-bottom:1px solid var(--border)}.action-item:last-child{border-bottom:none}.action-item-body{flex:1;min-width:0}.action-item-top{display:flex;align-items:center;gap:6px;flex-wrap:wrap;margin-bottom:3px}.action-item-desc{font-size:13px}.action-item-sub{font-size:12px;color:var(--muted);margin-top:2px}.breeding-item{display:flex;align-items:center;justify-content:space-between;gap:8px;padding:11px 0;border-bottom:1px solid var(--border)}.breeding-item:last-child{border-bottom:none}.breeding-item-pair{font-weight:600;font-size:14px}.breeding-item-date{font-size:12px;color:var(--muted);margin-top:2px}.puppy-row{display:flex;align-items:center;gap:12px;padding:9px 12px 9px 10px;border-radius:6px;cursor:pointer;transition:background .1s}.puppy-row:hover{background:var(--bg)}.litter-nav-row{transition:background .1s}.litter-nav-row:hover{background:var(--hover-bg)!important}.cal-grid-wrap{padding:0 4px}.cal-nav{display:flex;align-items:center;gap:8px;margin-bottom:12px}.cal-month-title{flex:1;font-size:16px;font-weight:600;text-transform:capitalize;min-width:110px;text-align:center}.cal-month-count{color:var(--muted);font-weight:400;font-size:13px;text-transform:none}.cal-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:1px;background:var(--border);border:1px solid var(--border);border-radius:8px;overflow:hidden}.cal-grid-week .cal-cell{min-height:320px}.cal-weekday{background:var(--bg);padding:8px 6px;font-size:11px;font-weight:700;color:var(--muted);text-transform:uppercase;letter-spacing:.04em;text-align:center}.cal-cell{background:var(--card);min-height:96px;padding:6px;display:flex;flex-direction:column;gap:4px;position:relative}.cal-cell.out{background:var(--bg)}.cal-cell.out .cal-day{color:var(--muted);opacity:.55}.cal-cell.today{box-shadow:inset 0 0 0 2px var(--accent)}.cal-cell.today .cal-day{background:var(--accent);color:#fff;border-radius:999px;width:22px;height:22px;display:inline-flex;align-items:center;justify-content:center;font-weight:700}.cal-day{font-size:12px;font-weight:600;color:var(--text);margin-bottom:1px}.cal-chip{display:block;text-align:left;line-height:1.35;font:inherit;font-size:11px;background:var(--accent-light);color:var(--accent);border:none;border-left:3px solid var(--accent);border-radius:3px;padding:2px 5px;cursor:inherit;overflow:hidden;white-space:nowrap;text-overflow:ellipsis;width:100%}.cal-chip:hover{filter:brightness(.96)}.cal-chip-link{cursor:pointer}.cal-chip-link:hover{filter:brightness(.88)}.cal-chip-link:focus-visible{outline:2px solid var(--accent);outline-offset:1px}.cal-chip-dropin{box-shadow:inset 0 0 0 1.5px currentColor}.cal-chip-time{font-weight:600}.cal-chip.disc-obedience{background:var(--green-light);color:var(--green);border-left-color:var(--green)}.cal-chip.disc-agility{background:var(--blue-light);color:var(--blue);border-left-color:var(--blue)}.cal-chip.disc-rally{background:var(--accent-light);color:var(--accent);border-left-color:var(--accent)}.cal-chip.disc-nose-work{background:var(--purple-light);color:var(--purple);border-left-color:var(--purple)}.cal-chip.disc-other{background:var(--yellow-light);color:var(--yellow);border-left-color:var(--yellow)}.cal-chip-due{background:rgba(184,134,11,.12);color:var(--yellow);border-left-color:var(--yellow)}.cal-chip-litter{background:rgba(42,122,75,.12);color:var(--green);border-left-color:var(--green)}.cal-chip-action{background:var(--bg);color:var(--text);border-left-color:var(--border)}.cal-chip-action.overdue{background:rgba(181,42,42,.1);color:var(--red);border-left-color:var(--red)}.cal-chip-action.done{text-decoration:line-through;color:var(--muted)}.cal-more{display:block;width:100%;text-align:left;background:transparent;border:none;font:inherit;font-size:10px;color:var(--muted);padding:2px 5px;cursor:pointer;border-radius:3px}.cal-more:hover{color:var(--text);background:var(--hover-bg)}.cal-view-toggle{display:inline-flex;border:1.5px solid var(--border);border-radius:6px;overflow:hidden;background:var(--card)}.cal-view-toggle-btn{background:transparent;border:none;padding:5px 12px;font-size:13px;font-weight:600;color:var(--muted);cursor:pointer;transition:background .1s,color .1s}.cal-view-toggle-btn+.cal-view-toggle-btn{border-left:1.5px solid var(--border)}.cal-view-toggle-btn:hover{background:var(--hover-bg);color:var(--text)}.cal-view-toggle-btn.active{background:var(--accent);color:#fff}.cal-today-btn{display:inline-flex;align-items:center}.cal-day-row{display:flex;align-items:center;gap:6px;margin-bottom:1px;min-height:18px}.cal-weekday-inline{display:none;font-size:11px;font-weight:700;color:var(--muted);text-transform:uppercase;letter-spacing:.04em}.cal-add-btn{margin-left:auto;opacity:0;background:transparent;border:1px solid var(--border);border-radius:4px;width:18px;height:18px;padding:0;font-size:13px;line-height:1;color:var(--muted);cursor:pointer;transition:opacity .1s,background .1s,color .1s,border-color .1s}.cal-cell:hover .cal-add-btn,.cal-cell:focus-within .cal-add-btn{opacity:1}.cal-add-btn:hover,.cal-add-btn:focus-visible{background:var(--accent);color:#fff;border-color:var(--accent);opacity:1}.cal-legend{display:flex;flex-wrap:wrap;gap:14px;padding:0;margin:0 0 12px;list-style:none;font-size:11px;color:var(--muted)}.cal-legend li{display:inline-flex;align-items:center;gap:5px}.cal-legend-dot{width:10px;height:10px;border-radius:2px;display:inline-block;flex-shrink:0}.cal-legend-dot-breeding{background:var(--accent)}.cal-legend-dot-due{background:var(--yellow)}.cal-legend-dot-litter{background:var(--green)}.cal-legend-dot-action{background:var(--border)}.cal-legend-dot-overdue{background:var(--red)}.cal-empty{text-align:center;padding:18px 8px 6px;font-size:13px;color:var(--muted)}@media (max-width: 600px){.cal-cell{min-height:64px;padding:4px}.cal-day{font-size:11px}.cal-chip{font-size:10px;padding:1px 3px}.cal-grid-week{grid-template-columns:1fr}.cal-grid-week .cal-weekday{display:none}.cal-grid-week .cal-cell{min-height:auto;padding:10px}.cal-grid-week .cal-weekday-inline{display:inline}.cal-add-btn{opacity:1}}@keyframes toast-slide-in{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.toast-stack{position:fixed;bottom:18px;right:18px;display:flex;flex-direction:column;gap:8px;z-index:500;max-width:calc(100vw - 32px);pointer-events:none}.toast{pointer-events:auto;display:flex;align-items:flex-start;gap:12px;min-width:240px;max-width:380px;padding:10px 12px 10px 14px;border-radius:8px;border:1px solid var(--border);background:var(--card);box-shadow:0 4px 18px #0000001f;font-size:14px;line-height:1.4;animation:toast-slide-in .16s ease-out}.toast-message{flex:1;min-width:0;word-break:break-word}.toast-dismiss{flex-shrink:0;background:none;border:none;color:var(--muted);cursor:pointer;font-size:16px;line-height:1;padding:2px 4px;border-radius:4px}.toast-dismiss:hover{color:var(--text)}.toast-info{border-left:3px solid var(--blue)}.toast-success{border-left:3px solid var(--green);background:var(--green-light)}.toast-error{border-left:3px solid var(--red);background:var(--red-light)}@keyframes flash-banner-in{0%{opacity:0;transform:translate(-50%,-12px)}to{opacity:1;transform:translate(-50%)}}.flash-banner{position:fixed;top:64px;left:50%;transform:translate(-50%);z-index:200;display:flex;align-items:flex-start;gap:14px;width:min(560px,calc(100vw - 24px));padding:12px 14px;background:var(--card);border:1px solid var(--border);border-radius:10px;box-shadow:0 8px 28px #00000029;animation:flash-banner-in .2s ease-out}.flash-banner-info{border-left:4px solid var(--blue);background:var(--blue-light)}.flash-banner-success{border-left:4px solid var(--green);background:var(--green-light)}.flash-banner-warning{border-left:4px solid var(--yellow);background:var(--yellow-light)}.flash-banner-body{flex:1;min-width:0}.flash-banner-title{font-weight:600;font-size:14px;line-height:1.3;color:var(--text)}.flash-banner-text{margin-top:4px;font-size:13px;line-height:1.4;color:var(--text)}.flash-banner-dismiss{flex-shrink:0;background:none;border:none;color:var(--muted);cursor:pointer;font-size:16px;line-height:1;padding:2px 6px;border-radius:4px}.flash-banner-dismiss:hover{color:var(--text);background:rgba(0,0,0,.06)}.flash-bell-wrap{position:relative;display:inline-flex}.flash-bell{position:relative;display:inline-flex;align-items:center;justify-content:center;background:transparent;border:1px solid var(--border);border-radius:6px;padding:5px 7px;cursor:pointer;color:var(--text)}.flash-bell:hover{background:rgba(0,0,0,.04)}.flash-bell-badge{position:absolute;top:-5px;right:-5px;min-width:16px;height:16px;padding:0 4px;background:var(--red);color:#fff;border-radius:10px;font-size:10px;font-weight:700;line-height:16px;text-align:center;box-shadow:0 0 0 2px var(--card)}.flash-board{position:absolute;right:0;top:calc(100% + 6px);width:min(340px,calc(100vw - 24px));max-height:70vh;display:flex;flex-direction:column;background:var(--card);border:1px solid var(--border);border-radius:10px;box-shadow:0 10px 32px #0000002e;z-index:300;overflow:hidden}.flash-board-header{display:flex;align-items:center;justify-content:space-between;padding:10px 12px;border-bottom:1px solid var(--border)}.flash-board-title{font-weight:600;font-size:14px;color:var(--text)}.flash-board-action{background:none;border:none;color:var(--accent);cursor:pointer;font-size:12px;padding:2px 6px;border-radius:4px}.flash-board-action:hover{background:var(--accent-light)}.flash-board-list{overflow-y:auto;padding:4px}.flash-board-empty{padding:18px 12px;text-align:center;color:var(--muted);font-size:13px}.flash-board-item{width:100%;text-align:left;display:block;padding:10px 10px 10px 14px;border:none;background:transparent;border-left:3px solid transparent;border-radius:6px;cursor:pointer;color:var(--text)}.flash-board-item:hover{background:rgba(0,0,0,.04)}.flash-board-item-info{border-left-color:var(--blue)}.flash-board-item-success{border-left-color:var(--green)}.flash-board-item-warning{border-left-color:var(--yellow)}.flash-board-item:not(.unread){opacity:.65}.flash-board-item-head{display:flex;align-items:center;justify-content:space-between;gap:8px}.flash-board-item-title{font-weight:600;font-size:13.5px;line-height:1.3}.flash-board-item-dot{flex-shrink:0;width:8px;height:8px;border-radius:50%;background:var(--accent)}.flash-board-item-body{margin-top:4px;font-size:12.5px;line-height:1.4;color:var(--text)}.flash-board-item-date{margin-top:6px;font-size:11px;color:var(--muted)}@media (max-width: 640px){.flash-banner{top:60px}.flash-board{position:fixed;top:60px;right:12px;left:12px;width:auto;max-height:calc(100vh - 80px)}}.onboarding-banner{display:flex;align-items:center;gap:14px;padding:14px 18px;margin-bottom:16px;background:var(--accent-light);border:1px solid var(--accent);border-radius:var(--radius)}.onboarding-icon{font-size:28px;line-height:1;flex-shrink:0}.onboarding-body{flex:1;min-width:0}.onboarding-title{font-weight:700;font-size:15px;color:var(--text)}.onboarding-subtitle{font-size:13px;color:var(--muted);margin-top:2px;line-height:1.4}@media (max-width: 600px){.onboarding-banner{flex-direction:column;align-items:stretch;text-align:left}.onboarding-banner .btn{align-self:flex-start}}@keyframes pk-row-add{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.pk-row-just-added{animation:pk-row-add .22s ease-out}body[data-density=compact] .card{padding:14px 16px}body[data-density=compact] .card-header{padding:12px 16px}body[data-density=compact] .form-row{margin-bottom:10px}body[data-density=compact] .form-group input,body[data-density=compact] .form-group select,body[data-density=compact] .form-group textarea{padding:6px 10px}body[data-density=compact] table th,body[data-density=compact] table td{padding:7px 10px}body[data-density=compact] .stat-card{padding:14px 16px}body[data-density=compact] .stat-value{font-size:26px}body[data-density=compact] .timeline-item{padding:8px 0}body[data-density=compact] .breeding-row{padding:9px 12px}body[data-density=compact] .puppy-row{padding:7px 10px 7px 8px}body[data-density=compact] .modal{padding:14px}body[data-density=compact] .modal-header{padding-bottom:10px}body[data-density=compact] .modal-footer{padding-top:10px}.animal-thumb,.animal-thumb-placeholder{width:32px;height:32px;flex:0 0 32px;border-radius:4px;display:inline-block;vertical-align:middle}.animal-thumb{object-fit:cover;border:1px solid var(--border)}.animal-thumb-placeholder{background:var(--bg);border:1px dashed var(--border)}.print-sheet-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:rgba(0,0,0,.5);z-index:50;overflow:auto;padding:24px;display:flex;flex-direction:column;align-items:center;gap:12px}.print-sheet-toolbar{display:flex;align-items:center;gap:8px;width:100%;max-width:820px;background:var(--card);border:1px solid var(--border);border-radius:var(--radius);padding:10px 14px}.print-sheet-toolbar-title{flex:1;font-weight:600;color:var(--text);min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.print-sheet-paper{background:#fff;color:#000;width:100%;max-width:820px;padding:48px 56px;box-shadow:0 6px 24px #0000002e;border-radius:4px;font-size:13px;line-height:1.5}.ps-letterhead{border-bottom:1px solid #ccc;padding-bottom:10px;margin-bottom:18px;text-align:right}.ps-letterhead-name{font-size:13px;font-weight:700;letter-spacing:.04em;text-transform:uppercase;color:#000}.ps-letterhead-meta,.ps-letterhead-contact{font-size:11px;color:#555;margin-top:2px}.ps-header{border-bottom:2px solid #000;padding-bottom:12px;margin-bottom:20px}.ps-header-flex{display:flex;gap:16px;align-items:flex-start}.ps-avatar{width:64px;height:64px;flex:0 0 64px;border-radius:50%;background:#f0f0f0;border:1px solid #999;display:flex;align-items:center;justify-content:center;font-size:22px;font-weight:700;color:#555}.ps-photo{width:96px;height:96px;flex:0 0 96px;border-radius:4px;object-fit:cover;border:1px solid #999;background:#f0f0f0}.ps-title{font-size:24px;font-weight:700;margin:0;color:#000}.ps-subtitle{font-size:14px;color:#555;margin-top:4px}.ps-pills{display:flex;gap:6px;margin-top:8px;flex-wrap:wrap}.ps-pill{font-size:11px;padding:2px 8px;border:1px solid #000;border-radius:10px}.ps-notes-lines{display:flex;flex-direction:column;gap:14px;padding-top:8px}.ps-notes-lines span{display:block;border-bottom:1px solid #999;height:0}.ps-legend{list-style:none;margin:8px 0 0;padding:0;display:flex;flex-wrap:wrap;gap:6px 16px;font-size:11px;color:#333}.ps-legend li{display:flex;align-items:center;gap:6px}.ps-legend-swatch{width:14px;height:3px;border-radius:2px;display:inline-block}.ps-section{margin-bottom:22px;page-break-inside:avoid}.ps-section-title{font-size:11px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;border-bottom:1px solid #000;padding-bottom:4px;margin:0 0 10px;color:#000}.ps-grid{display:grid;grid-template-columns:max-content 1fr;gap:4px 18px;margin:0}.ps-grid dt{font-weight:600;color:#555}.ps-grid dd{margin:0;color:#000}.ps-litter-row{padding:4px 0}.ps-parent-dd{display:flex;align-items:center;gap:10px;margin:0}.ps-parent-thumb{width:36px;height:36px;object-fit:cover;border-radius:4px;border:1px solid #999;flex-shrink:0}.ps-cover{width:120px;height:120px;object-fit:cover;border-radius:6px;border:1px solid #999;display:block;margin:0 auto 10px}.ps-table{width:100%;border-collapse:collapse;font-size:12px}.ps-table th,.ps-table td{padding:5px 8px;text-align:left;border-bottom:1px solid #ccc}.ps-table th{border-bottom:2px solid #000;font-weight:700}.ps-footer{margin-top:24px;padding-top:10px;border-top:1px solid #ccc;font-size:11px;color:#777;text-align:right}@media print{body:has(.print-sheet-overlay) .app-shell{display:none!important}body:has(.print-sheet-overlay){background:#fff}.print-sheet-overlay{position:static;background:transparent;padding:0;display:block}.print-sheet-paper{box-shadow:none;padding:0;max-width:none;border-radius:0}.ps-section,.ps-notes{page-break-inside:avoid}.ps-legend-swatch,.print-sheet-paper svg polyline,.print-sheet-paper svg circle{-webkit-print-color-adjust:exact;print-color-adjust:exact}}@page{size:A4}.admin-main{margin-left:auto;margin-right:auto;width:100%}.admin-subnav{display:flex;gap:4px;padding:8px 20px;border-bottom:1px solid var(--border);background:var(--card)}.section-title{font-size:14px;color:var(--muted);text-transform:uppercase;letter-spacing:.5px;margin:0 0 12px}.invite-share-card{border-color:var(--accent)}.plan-card{display:flex;flex-direction:column}.plan-card-current{border-color:var(--accent);border-width:2px}.btn-danger[disabled],.btn-danger:disabled{opacity:.5;cursor:not-allowed}@media (max-width: 599px){.hero{padding:28px 16px 16px}.hero h1{font-size:24px}.hero p{font-size:14px}.portal-grid{gap:10px;padding:0 14px 28px}.portal-card{padding:16px;gap:8px}.portal-icon{font-size:28px}.portal-features{display:none}.portal-grid--compact{grid-template-columns:repeat(2,1fr);gap:8px;padding:0 12px 24px}.portal-grid--compact .portal-card{padding:10px 8px}.portal-grid--compact .portal-icon{font-size:30px}.portal-grid--large .portal-card{padding:22px}.portal-grid--large .portal-icon{font-size:44px}.portal-grid--large .portal-title{font-size:20px}}.agility-designer{display:flex;flex-direction:column;height:100%;overflow:hidden}.agility-body{display:flex;flex:1;overflow:hidden;gap:0}.agility-toolbar{display:flex;flex-wrap:nowrap;gap:8px;padding:6px 12px;border-bottom:1px solid var(--border);background:var(--card);align-items:center;overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none;position:relative;z-index:5}.agility-toolbar::-webkit-scrollbar{display:none}.agility-toolbar-group{display:flex;align-items:center;gap:6px;padding-right:8px;border-right:1px solid var(--border)}.agility-toolbar-group:last-child{border-right:none}.agility-toolbar-label{font-size:11px;font-weight:600;color:var(--muted);text-transform:uppercase;letter-spacing:.04em;margin-right:2px}.agility-toolbar-sep{color:var(--muted);font-size:13px}.agility-toolbar-oob-warn{font-size:11px;font-weight:600;color:#8a5a00;white-space:nowrap;margin-left:4px;display:inline-flex;align-items:center;gap:3px}body[data-theme=dark] .agility-toolbar-oob-warn{color:var(--yellow)}.agility-toolbar input[type=number]{padding:3px 5px;border:1px solid var(--border);border-radius:4px;background:var(--bg);color:var(--text);font-size:13px;text-align:center}.agility-toolbar input[type=number]:focus-visible,.agility-toolbar select:focus-visible{outline:2px solid var(--accent);outline-offset:1px}.agility-toolbar select{padding:3px 5px;border:1px solid var(--border);border-radius:4px;background:var(--bg);color:var(--text);font-size:13px}.agility-toolbar input[type=range]{accent-color:var(--accent);height:20px;min-width:64px;vertical-align:middle}.agility-zoom-overlay{position:absolute;bottom:12px;right:12px;display:flex;align-items:center;gap:2px;background:var(--card);border:1px solid var(--border);border-radius:6px;padding:3px 4px;box-shadow:0 2px 8px #0000001f;z-index:10;-webkit-user-select:none;user-select:none}.agility-canvas-wrap>.agility-zoom-overlay{position:absolute;bottom:16px;right:16px;z-index:11}@media (max-width: 700px){.agility-canvas-wrap>.agility-zoom-overlay{bottom:80px;right:12px}}body[data-theme=dark] .agility-zoom-overlay{box-shadow:0 2px 8px #00000059}.agility-zoom-step{padding:2px 7px;font-size:14px;font-weight:600;min-width:26px;text-align:center}.agility-zoom-reset{padding:2px 6px;font-size:11px;min-width:38px;text-align:center;font-variant-numeric:tabular-nums}.agility-setup-group{position:relative}.agility-setup-btn{display:flex;align-items:center;gap:5px;max-width:260px}.agility-setup-summary{font-size:12px;color:var(--text);opacity:.75;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.agility-setup-btn.active{background:rgba(200,98,42,.08);border-color:var(--accent);border-bottom-color:var(--card);border-bottom-left-radius:0;border-bottom-right-radius:0;color:var(--text)}.agility-setup-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:999}.agility-setup-popover{position:fixed;z-index:1000;background:var(--card);border:1px solid var(--accent);border-top:none;border-radius:0 8px 8px;box-shadow:0 4px 20px #00000021;padding:12px 16px;display:flex;flex-direction:column;gap:10px;min-width:280px;max-width:min(320px,calc(100vw - 24px))}body[data-theme=dark] .agility-setup-popover{box-shadow:0 4px 20px #0006;border-color:var(--accent)}.agility-setup-close-btn{align-self:flex-end;background:none;border:1px solid var(--border);border-radius:6px;color:var(--muted);cursor:pointer;font-size:11px;padding:3px 8px;margin-top:2px}.agility-setup-close-btn:hover{color:var(--text);background:var(--bg)}.agility-setup-row{display:flex;align-items:center;gap:10px}.agility-setup-row-label{font-size:11px;font-weight:600;color:var(--muted);text-transform:uppercase;letter-spacing:.04em;width:44px;flex-shrink:0}.agility-setup-row-controls{display:flex;align-items:center;gap:6px}.agility-setup-popover input[type=number]{padding:4px 6px;border:1px solid var(--border);border-radius:5px;background:var(--bg);color:var(--text);font-size:13px;text-align:center}.agility-setup-popover input[type=number]:focus-visible,.agility-setup-popover select:focus-visible{outline:2px solid var(--accent);outline-offset:1px}.agility-setup-popover select{padding:4px 6px;border:1px solid var(--border);border-radius:5px;background:var(--bg);color:var(--text);font-size:13px}.agility-btn{padding:4px 10px;border:1px solid var(--border);border-radius:8px;background:var(--bg);color:var(--text);font-size:12px;font-weight:500;cursor:pointer;transition:background .12s,color .12s,border-color .15s,opacity .12s;white-space:nowrap}.agility-btn:hover{background:var(--card)}.agility-btn:active{background:var(--border)}.agility-btn.active{background:#a84e20;color:#fff;border-color:#a84e20}.agility-btn.active:hover{opacity:.88}.agility-btn-primary{background:#a84e20;color:#fff;border-color:#a84e20;font-size:14px;font-weight:600}.agility-btn-primary:hover{opacity:.88}.agility-btn-primary:active{opacity:.78}.agility-btn-outline{color:var(--accent);border-color:var(--accent);font-weight:600}.agility-btn-outline:hover{background:var(--accent);color:#fff}.agility-btn-danger{color:#9a2020;border-color:#9a2020}.agility-btn-danger:hover,.agility-btn-danger:active{background:var(--red);color:#fff}body[data-theme=dark] .agility-btn-danger{color:var(--red);border-color:var(--red)}.agility-btn-ghost{color:var(--muted);border-color:transparent;background:transparent}.agility-btn-ghost:hover{color:var(--text);border-color:var(--border);background:var(--card)}.agility-btn-ghost:disabled{opacity:.4}.agility-toolbar-violation{font-size:11px;font-weight:700;color:#9a2020;white-space:nowrap;display:flex;align-items:center;padding:2px 8px;background:rgba(239,68,68,.1);border:1px solid rgba(239,68,68,.3);border-radius:12px;flex-shrink:0;cursor:pointer;font-family:inherit}.agility-toolbar-violation:hover{background:rgba(239,68,68,.2);border-color:#ef444480}.agility-toolbar-violation:focus-visible{outline:2px solid var(--red, #ef4444);outline-offset:2px}body[data-theme=dark] .agility-toolbar-violation{color:var(--red);background:rgba(239,68,68,.15);border-color:#ef444466}body[data-theme=dark] .agility-btn-danger:hover,body[data-theme=dark] .agility-btn-danger:active{color:#1a1a1a}.agility-btn-sm{font-size:12px;padding:3px 7px}.agility-btn:disabled{opacity:.4;cursor:not-allowed}.agility-btn:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.agility-btn-primary:focus-visible,.agility-btn.active:focus-visible{outline-color:#fff;outline-offset:3px}.agility-canvas-wrap svg:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.agility-palette-wrap{display:flex;flex-direction:row;flex-shrink:0;border-right:1px solid var(--border);transition:width .2s ease;width:180px;position:relative}.agility-palette-wrap.collapsed{width:20px}.agility-palette-collapse-btn{position:absolute;right:0;top:50%;transform:translateY(-50%);width:20px;height:40px;border:none;border-left:1px solid var(--border);background:var(--card);color:var(--muted);cursor:pointer;font-size:13px;display:flex;align-items:center;justify-content:center;z-index:2;border-radius:4px 0 0 4px;padding:0}.agility-palette-wrap.collapsed .agility-palette-collapse-btn{left:0;right:auto;border-left:none;border-right:1px solid var(--border);border-radius:0 4px 4px 0}.agility-palette-collapse-btn:hover{color:var(--text);background:var(--bg)}.agility-palette-collapse-btn:focus-visible{outline:2px solid var(--accent);outline-offset:-2px}.agility-palette{flex:1;overflow-y:auto;background:var(--card);padding:8px 0;min-width:0}.agility-palette-group{margin-bottom:4px}.agility-palette-group+.agility-palette-group{margin-top:8px}.agility-palette-cat{font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--muted);padding:4px 8px;margin:4px 8px;background:rgba(0,0,0,.04);border-left-width:4px;border-left-style:solid;border-left-color:transparent;border-radius:0 4px 4px 0}body[data-theme=dark] .agility-palette-cat{background:rgba(255,255,255,.06)}.agility-palette-item{display:flex;align-items:center;gap:8px;width:100%;padding:8px 10px;min-height:44px;border:none;background:transparent;color:var(--text);font-size:12px;cursor:pointer;text-align:left;transition:background .1s;border-radius:0}.agility-palette-item:hover{background:var(--bg)}.agility-palette-item:active{background:var(--border)}.agility-palette-item.active{font-weight:700;background:rgba(200,98,42,.1);border-left:3px solid var(--accent);padding-left:7px}.agility-palette-item.active:hover{background:rgba(200,98,42,.15);opacity:1}.agility-palette-item:focus-visible{outline:2px solid var(--accent);outline-offset:-2px}.agility-palette-item.active:focus-visible{outline-color:var(--accent);outline-offset:-3px}.agility-palette-selected-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0;display:inline-block}.agility-palette-item:disabled{color:var(--muted);cursor:not-allowed;pointer-events:none;opacity:.5}.agility-palette-item:disabled .agility-palette-dot{opacity:.5}.agility-print-summary{display:none}.agility-toolbar-field-swatch{transition:opacity .12s}.agility-toolbar-field-swatch:hover{opacity:.8}.agility-toolbar-field-swatch:active{opacity:.65}.agility-toolbar-field-swatch:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.agility-palette-dot{width:9px;height:9px;border-radius:50%;flex-shrink:0}.agility-palette-selected{margin:8px 8px 0;padding:8px;border:1px solid var(--border);border-left:3px solid var(--accent);border-radius:6px;background:var(--bg);display:flex;flex-direction:column;gap:8px}.agility-palette-preview{width:100%;border-radius:6px;overflow:hidden;border:1px solid var(--border);background:var(--card);line-height:0}.agility-palette-count{margin-left:auto;font-size:10px;font-weight:700;color:var(--muted);background:var(--border);border-radius:8px;padding:1px 5px;flex-shrink:0}.agility-palette-count.over{color:var(--yellow);background:rgba(245,158,11,.15)}.agility-palette-selected-title{font-size:12px;font-weight:700;color:var(--text);border-bottom:1px solid var(--border);padding-bottom:4px;margin-bottom:4px}.agility-palette-selected-row{display:flex;align-items:center;gap:6px;font-size:12px;color:var(--muted)}.agility-palette-selected-row input{padding:2px 5px;border:1px solid var(--border);border-radius:4px;background:var(--card);color:var(--text);font-size:12px}.agility-palette-selected-row input:focus-visible{outline:2px solid var(--accent);outline-offset:1px}.agility-selected-bar-order:focus-visible{outline:2px solid var(--accent);outline-offset:1px}.agility-palette-visits{display:flex;flex-wrap:wrap;gap:4px;align-items:center}.agility-palette-visit-chip{display:inline-flex;align-items:center;gap:2px;background:var(--agility-badge);color:#fff;font-size:11px;font-weight:700;border-radius:8px;padding:2px 4px 2px 6px}.agility-palette-visit-remove{background:none;border:none;color:#fffc;font-size:12px;cursor:pointer;padding:0 2px;line-height:1}.agility-palette-visit-remove:hover{color:#fff}.agility-selected-bar-visits{font-size:13px;font-weight:700;color:var(--text);padding:2px 6px;background:var(--bg);border:1px solid var(--border);border-radius:4px;min-width:32px;text-align:center}.agility-canvas-wrap{flex:1;overflow:hidden;position:relative;background:var(--bg)}.agility-canvas-scroll{width:100%;height:100%;overflow:auto;padding:8px;box-sizing:border-box;touch-action:pan-x pan-y}@media (max-width: 600px){.agility-canvas-scroll{padding:4px;overflow:auto}.agility-canvas-scroll .agility-canvas-svg{display:block;margin:0 auto}}.agility-reorder-banner,.agility-placing-banner{position:absolute;bottom:12px;left:50%;transform:translate(-50%);background:var(--agility-badge);color:#fff;padding:8px 16px;border-radius:20px;font-size:13px;z-index:10;display:flex;align-items:center;gap:10px;pointer-events:auto;white-space:nowrap;max-width:calc(100vw - 24px);box-shadow:0 4px 16px #00000059}.agility-reorder-banner>span,.agility-placing-banner>span{overflow:hidden;text-overflow:ellipsis;min-width:0}.agility-placing-banner,body[data-theme=dark] .agility-placing-banner{background:var(--blue)}.agility-auto-load-notice{position:absolute;top:12px;left:50%;transform:translate(-50%);background:var(--green);color:#fff;padding:6px 16px;border-radius:20px;font-size:12px;z-index:10;white-space:nowrap;pointer-events:none;animation:agility-obs-in .2s ease-out both}.agility-analysis-wrap{display:flex;flex-direction:row;flex-shrink:0;border-left:1px solid var(--border);transition:width .2s ease;width:240px;position:relative}.agility-analysis-wrap.collapsed{width:32px}.agility-analysis-toggle{position:absolute;left:0;top:50%;transform:translateY(-50%);width:24px;height:48px;border:none;border-right:1px solid var(--border);background:var(--card);color:var(--muted);cursor:pointer;font-size:13px;display:flex;align-items:center;justify-content:center;z-index:2;border-radius:0 4px 4px 0;flex-shrink:0;padding:0}.agility-analysis-toggle:hover{color:var(--text);background:var(--bg)}.agility-analysis-toggle:focus-visible{outline:2px solid var(--accent);outline-offset:-2px}.agility-analysis-toggle-mobile{display:none}.agility-analysis-toggle-desktop{display:block}.agility-analysis-badge{position:absolute;top:4px;right:2px;width:9px;height:9px;border-radius:50%;border:1.5px solid var(--card)}.agility-analysis-badge-error{background:var(--red);animation:agility-badge-pulse 1.8s ease-in-out infinite}.agility-analysis-badge-warn{background:var(--yellow)}.agility-analysis-badge-ok{background:var(--green);width:7px;height:7px}@keyframes agility-badge-pulse{0%,to{transform:scale(1);opacity:1}50%{transform:scale(1.4);opacity:.75}}@media (prefers-reduced-motion: reduce){.agility-analysis-badge-error{animation:none}}.agility-analysis{flex:1;overflow-y:auto;background:var(--card);padding:12px 12px 12px 30px;display:flex;flex-direction:column;gap:8px;min-width:0}.agility-analysis-empty{color:var(--muted);font-size:13px;text-align:center;margin-top:24px;line-height:1.5}.agility-analysis-stat{display:flex;justify-content:space-between;align-items:baseline;padding:8px 0;border-bottom:1px solid var(--border)}.agility-stat-label{font-size:12px;color:var(--muted);font-weight:500}.agility-stat-value{font-size:16px;font-weight:700;color:var(--text)}.agility-rule-section{display:flex;flex-direction:column;gap:4px}.agility-rule-header{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.05em;margin-top:8px;color:var(--muted);background:transparent}.agility-rule-item.agility-rule-header{color:var(--muted);background:transparent}.agility-rule-item{font-size:12px;line-height:1.4;padding:4px 8px;border-radius:4px}.agility-rule-error{color:var(--red);background:rgba(239,68,68,.08)}body[data-theme=dark] .agility-rule-error{color:#fca5a5}.agility-rule-warn{color:#7a5800;background:rgba(245,158,11,.1)}.agility-rule-ok{color:var(--green);background:rgba(34,197,94,.1)}.agility-rule-info{color:var(--muted);font-size:12px}body[data-theme=dark] .agility-rule-warn{color:var(--yellow)}.agility-reorder-warning{color:#fca5a5}body[data-theme=dark] .agility-reorder-warning{color:#fff}.agility-times{margin-top:8px}.agility-times-header{font-size:11px;font-weight:700;color:var(--muted);text-transform:uppercase;letter-spacing:.04em;margin-bottom:8px}.agility-times-table{width:100%;border-collapse:collapse;font-size:12px}.agility-times-table th{text-align:left;padding:5px 6px;color:var(--muted);font-weight:600;border-bottom:1px solid var(--border);font-size:11px}.agility-times-table td{padding:5px 6px;color:var(--text);border-bottom:1px solid var(--border)}.agility-times-table tr:last-child td{border-bottom:none}.agility-times-table strong{color:var(--text);font-weight:700}.agility-times-note{font-size:11px;color:var(--muted);margin-top:4px;font-style:italic}.agility-auto{padding:24px;overflow-y:auto;height:100%;display:flex;flex-direction:column;gap:24px}.agility-auto-form{max-width:600px}.agility-auto-title{font-size:22px;font-weight:700;margin:0 0 8px}.agility-auto-desc{color:var(--muted);font-size:14px;margin:0 0 24px;line-height:1.5}.agility-auto-fields{display:flex;flex-direction:column;gap:16px}.agility-auto-field{display:flex;flex-direction:column;gap:4px}.agility-auto-field label,.agility-auto-field-legend{font-size:12px;font-weight:600;color:var(--muted);text-transform:uppercase;letter-spacing:.04em;padding:0;margin-bottom:4px;display:block}.agility-auto-field select,.agility-auto-field input[type=number]{padding:6px 8px;border:1px solid var(--border);border-radius:6px;background:var(--bg);color:var(--text);font-size:14px;max-width:220px}.agility-auto-field select:focus-visible,.agility-auto-field input[type=number]:focus-visible{outline:2px solid var(--accent);outline-offset:1px}.agility-auto-result{display:flex;gap:24px;flex-wrap:wrap;align-items:flex-start}.agility-auto-canvas{flex-shrink:0;width:min(400px,100%);position:relative;border:1px solid var(--border);border-radius:8px;overflow:hidden}.agility-auto-canvas-scroll{width:100%;overflow:auto;touch-action:pan-x pan-y}.agility-auto-actions{display:flex;gap:8px;flex-wrap:wrap;align-items:center;margin-top:24px}.agility-auto-official-toggle{display:flex;align-items:center;gap:6px;font-size:13px;font-weight:600;color:var(--text);cursor:pointer;padding:6px 10px;border:1.5px solid var(--border);border-radius:6px;background:var(--card);-webkit-user-select:none;user-select:none}.agility-auto-official-toggle:has(input:checked){border-color:#15803d;background:#f0fdf4;color:#14532d}body[data-theme=dark] .agility-auto-official-toggle:has(input:checked){background:rgba(21,128,61,.15);color:#4ade80;border-color:#16a34a}.agility-auto-official-toggle input{margin:0}.agility-auto-official-badge{padding:8px 14px;background:#f0fdf4;border:1.5px solid #15803d;border-radius:8px;font-size:13px;font-weight:700;color:#14532d;text-align:center}body[data-theme=dark] .agility-auto-official-badge{background:rgba(21,128,61,.18);border-color:#16a34a;color:#4ade80}.agility-auto-stats{display:flex;flex-direction:column;gap:8px;min-width:240px;max-width:320px}.agility-auto-empty{color:var(--muted);font-size:14px;line-height:1.5;padding:32px;border:2px dashed var(--muted);border-radius:12px;text-align:center;max-width:480px}.agility-auto-warning{font-size:12px;color:#8a5a00}body[data-theme=dark] .agility-auto-warning{color:var(--yellow)}.agility-auto-stale{margin-top:8px;padding:8px 12px;background:#fff8e1;border:1px solid #f59e0b;border-radius:6px;font-size:12px;color:#78350f}body[data-theme=dark] .agility-auto-stale{background:rgba(245,158,11,.12);border-color:#b45309;color:var(--yellow)}.agility-type-groups{display:flex;flex-direction:column;gap:8px}.agility-type-group-label{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.04em;color:var(--muted);margin-bottom:4px}.agility-type-chips{display:flex;flex-wrap:wrap;gap:4px}.agility-obs-toggle{display:inline-flex;align-items:center;justify-content:center;padding:3px;border-radius:6px;cursor:pointer;border:2px solid var(--border);background:var(--bg);transition:opacity .12s,border-color .12s,box-shadow .12s;-webkit-user-select:none;user-select:none;opacity:.35}.agility-obs-toggle.active{opacity:1;border-color:var(--accent);box-shadow:0 0 0 1px var(--accent)}.agility-obs-toggle:hover{opacity:.75}.agility-obs-toggle:focus-visible{outline:2px solid var(--accent);outline-offset:1px}@media (max-width: 700px){.agility-palette,.agility-palette-wrap{display:none}.agility-body{flex-direction:column}.agility-analysis-wrap{width:100%;flex-direction:column;border-left:none;border-top:1px solid var(--border)}.agility-analysis-wrap.collapsed{width:100%;height:36px;overflow:hidden}.agility-analysis-toggle{position:static;transform:none;width:100%;height:40px;border-right:none;border-bottom:1px solid var(--border);border-radius:0;font-size:13px;font-weight:600;gap:6px}.agility-analysis-wrap.collapsed{height:40px}.agility-analysis{border-left:none;padding:8px 12px;max-height:45vh}.agility-analysis-toggle-desktop{display:none}.agility-analysis-toggle-mobile{display:block;font-size:13px;font-weight:600;color:var(--text)}.agility-canvas-wrap{flex:1;min-height:0;overflow:hidden}}.agility-toolbar-overflow-btn{display:none}.agility-actions-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:999}.agility-actions-menu{position:fixed;z-index:1000;background:var(--card);border:1px solid var(--border);border-radius:10px;box-shadow:0 4px 20px #0000002e;min-width:200px;padding:4px;display:flex;flex-direction:column;gap:2px}.agility-actions-menu-item{display:block;width:100%;text-align:left;padding:11px 14px;border:none;border-radius:7px;background:transparent;color:var(--text);font-size:14px;font-weight:500;cursor:pointer}.agility-actions-menu-item:hover{background:var(--bg)}.agility-actions-menu-item:disabled{opacity:.4;cursor:default}.agility-actions-menu-item--primary{color:var(--accent)}.agility-actions-menu-item--danger{color:var(--red)}.agility-actions-menu-divider{height:1px;background:var(--border);margin:2px 6px}@media (max-width: 700px){.agility-toolbar-toggles,.agility-toolbar-zoom,.agility-toolbar-print,.agility-toolbar-actions{display:none!important}.agility-toolbar-overflow-btn{display:flex;align-items:center;margin-left:auto;min-height:44px;padding:0 12px;font-size:18px;letter-spacing:1px}.agility-setup-summary{display:none}.agility-setup-popover{min-width:min(90vw,300px)}.agility-toolbar{padding:4px 8px;gap:4px}.agility-toolbar-group{border-right:none;gap:4px;padding-right:4px}.agility-selected-bar .agility-btn-sm,.agility-selected-bar-title .agility-btn-sm{min-height:44px;padding:0 12px}}.agility-palette-sheet-overlay{display:none}@media (max-width: 700px){.agility-palette-sheet-overlay{display:block;position:fixed;top:0;right:0;bottom:0;left:0;background:rgba(0,0,0,.45);z-index:200}.agility-palette-sheet{position:absolute;bottom:0;left:0;right:0;background:var(--card);border-radius:16px 16px 0 0;max-height:72vh;overflow-y:auto;padding:8px 16px 24px}.agility-palette-sheet-drag-handle{width:36px;height:4px;background:var(--muted);border-radius:2px;margin:0 auto 12px;opacity:.5}.agility-palette-sheet-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px;font-weight:600;font-size:15px}.agility-palette-sheet-close{background:var(--bg);border:1px solid var(--border);border-radius:50%;width:44px;height:44px;cursor:pointer;font-size:16px;color:var(--text);display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:background .12s}.agility-palette-sheet-close:hover{background:var(--border)}.agility-palette-sheet-close:active{background:var(--border);opacity:.75}.agility-palette-sheet-close:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.agility-palette-sheet-grid{display:flex;flex-direction:column;gap:14px}.agility-sheet-cat-header{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.04em;color:var(--muted);padding-left:8px;margin-bottom:8px}.agility-sheet-cat-items{display:grid;grid-template-columns:repeat(3,1fr);gap:6px}.agility-sheet-item{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:5px;padding:10px 4px;border-radius:8px;border:1px solid var(--border);background:var(--card);cursor:pointer;font-size:11px;font-weight:500;color:var(--text);text-align:center;min-height:56px;transition:background .12s}.agility-sheet-item:hover{background:var(--bg);border-color:var(--accent)}.agility-sheet-item:active{background:var(--accent);color:#fff}.agility-sheet-item:active .agility-palette-dot{background:#fff!important}.agility-sheet-item:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.agility-sheet-item:disabled{opacity:.42;cursor:not-allowed;pointer-events:none}.agility-sheet-item:disabled .agility-palette-dot{opacity:.5}.agility-sheet-item .agility-palette-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0}}.agility-fab{display:none}@media (max-width: 700px){.agility-fab{display:flex;align-items:center;justify-content:center;position:absolute;bottom:16px;right:16px;width:52px;height:52px;border-radius:50%;background:var(--accent);color:#fff;border:none;cursor:pointer;font-size:22px;font-weight:700;z-index:15;box-shadow:0 4px 14px #00000038;transition:transform .12s}.agility-fab:active{transform:scale(.94)}.agility-fab:focus-visible{outline:3px solid #fff;outline-offset:3px}.agility-fab.placing:focus-visible{border-radius:26px}.agility-placing-banner{bottom:80px}.agility-canvas-wrap.has-selection .agility-placing-banner{bottom:180px}.agility-fab.placing{border-radius:26px;width:auto;padding:0 16px;font-size:13px;background:var(--blue)}body[data-theme=dark] .agility-fab.placing{background:var(--blue)}.agility-canvas-wrap.has-selection .agility-fab{bottom:120px}}.agility-selected-bar{display:none}@media (max-width: 700px){.agility-selected-bar{display:flex;flex-direction:column;gap:6px;padding:8px 12px;background:var(--card);border-top:1px solid var(--border);box-shadow:0 -2px 8px #0000001a;position:absolute;bottom:0;left:0;right:0;z-index:20}.agility-selected-bar-title{display:flex;align-items:center;gap:8px}.agility-selected-bar-name{font-size:13px;font-weight:600;flex:1;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.agility-selected-bar-actions{display:flex;gap:6px;align-items:center;flex-wrap:wrap}.agility-selected-bar-order{width:48px;min-height:44px;padding:4px 6px;border:1px solid var(--border);border-radius:4px;font-size:13px;text-align:center;background:var(--bg);color:var(--text)}}.agility-banner-cancel,.agility-banner-done{background:rgba(255,255,255,.2);border:1px solid rgba(255,255,255,.4);color:#fff;border-radius:6px;padding:10px 16px;min-height:44px;cursor:pointer;font-size:13px;font-weight:600;white-space:nowrap;flex-shrink:0;display:flex;align-items:center}.agility-banner-cancel:hover,.agility-banner-done:hover{background:rgba(255,255,255,.32)}.agility-banner-cancel:active,.agility-banner-done:active{background:rgba(255,255,255,.38)}.agility-banner-cancel:focus-visible,.agility-banner-done:focus-visible{outline:2px solid #fff;outline-offset:2px}@media (max-width: 700px){.agility-auto-actions{display:flex;flex-direction:column;gap:8px;width:100%;margin-top:12px}.agility-auto-actions .agility-btn{width:100%;justify-content:center;min-height:44px;padding:0 16px}.agility-auto-field select,.agility-auto-field input{max-width:100%!important;width:100%}.agility-auto-stats{min-width:0;width:100%;max-width:100%}}.agility-canvas-empty-hint{position:absolute;top:40%;left:50%;transform:translate(-50%,-50%);pointer-events:none;color:var(--muted);text-align:center;background:var(--card);padding:12px 20px;border-radius:10px;border:1px dashed var(--border);font-size:13px;line-height:1.5;max-width:min(320px,calc(100vw - 32px));z-index:5}.agility-canvas-empty-hint-desktop{display:inline}.agility-canvas-empty-hint-mobile{display:none}@media (max-width: 700px){.agility-canvas-empty-hint-desktop{display:none}.agility-canvas-empty-hint-mobile{display:inline-flex;align-items:center;gap:6px}}.agility-fab-hint-icon{font-size:18px;font-weight:700;color:var(--accent)}.agility-auto-canvas-btn{position:relative;background:none;border:none;padding:0;cursor:pointer;display:block}.agility-auto-canvas-btn:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.agility-auto-canvas-overlay{position:absolute;top:0;right:0;bottom:0;left:0;background:rgba(0,0,0,0);color:transparent;display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:600;border-radius:8px;transition:background .15s,color .15s}.agility-auto-canvas-btn:hover .agility-auto-canvas-overlay{background:rgba(0,0,0,.35);color:#fff}@keyframes agility-obs-in{0%{opacity:0}to{opacity:1}}.agility-obs-new{animation:agility-obs-in .22s ease-out both}@media (prefers-reduced-motion: reduce){.agility-obs-new{animation:none}}.agility-times-scroll{overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none}.agility-times-scroll::-webkit-scrollbar{display:none}.track-library{display:flex;flex-direction:column;height:100%;overflow:hidden;background:var(--bg)}.track-library-header{padding:16px 20px 0;background:var(--card);border-bottom:1px solid var(--border);flex-shrink:0;display:flex;flex-wrap:wrap;gap:12px;align-items:center}.track-library-title{font-size:18px;font-weight:700;margin:0;color:var(--text);flex-shrink:0}.track-library-tabs{display:flex;gap:4px}.track-tab{background:none;border:none;padding:8px 14px;font-size:14px;font-weight:500;color:var(--muted);cursor:pointer;border-bottom:2px solid transparent;margin-bottom:-1px;transition:color .15s,border-color .15s}.track-tab:hover{color:var(--text)}.track-tab.active{color:var(--accent);border-bottom-color:var(--accent)}.track-library-search{margin-left:auto;padding-bottom:12px}.track-library-search-input{border:1.5px solid var(--border);border-radius:6px;padding:6px 10px;font-size:13px;background:var(--bg);color:var(--text);outline:none;width:200px;transition:border-color .15s}.track-library-search-input:focus{border-color:var(--accent)}.track-library-body{flex:1;overflow-y:auto;padding:20px}.track-library-loading{display:flex;flex-direction:column;gap:12px}.track-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:16px}.track-card{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);padding:14px 16px;display:flex;flex-direction:column;gap:6px;box-shadow:var(--shadow);transition:box-shadow .15s,border-color .15s}.track-card:hover{border-color:var(--accent);box-shadow:0 2px 8px #0000001a}.track-card-skeleton{min-height:110px;background:linear-gradient(90deg,var(--border) 25%,var(--hover-bg) 50%,var(--border) 75%);background-size:400% 100%;animation:skeleton-shimmer 1.4s ease-in-out infinite}@keyframes skeleton-shimmer{0%{background-position:100% 0}to{background-position:-100% 0}}.track-card-header{display:flex;align-items:center;gap:8px}.track-card-name{font-weight:600;font-size:15px;color:var(--text);flex:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.track-card-badge{font-size:10px;font-weight:700;padding:2px 6px;border-radius:10px;flex-shrink:0}.track-card-badge.public{background:var(--green-light);color:var(--green)}.track-card-badge.shared{background:var(--blue-light);color:var(--blue)}.track-card-meta{font-size:12px;color:var(--muted);display:flex;flex-wrap:wrap;gap:4px;align-items:center}.track-card-owner{color:var(--muted);font-style:italic}.track-card-date{font-size:11px;color:var(--muted)}.track-card-actions{display:flex;gap:8px;margin-top:4px;flex-wrap:wrap}.btn-outline{background:transparent;border:1.5px solid var(--border);color:var(--text)}.btn-outline:hover{background:var(--hover-bg);border-color:var(--accent);color:var(--accent)}.empty-state{text-align:center;padding:48px 24px;color:var(--muted)}.empty-state p{margin:6px 0}.empty-state.error{color:var(--red)}.track-share-email-input{flex:1;padding:6px 10px;border:1px solid var(--border);border-radius:6px;background:var(--bg);color:var(--text);font-size:14px;min-width:0}.track-share-email-input:focus{border-color:var(--accent);outline:none}.track-share-list{list-style:none;display:flex;flex-direction:column;gap:4px;max-height:200px;overflow-y:auto}.track-share-item{display:flex;align-items:center;justify-content:space-between;padding:6px 10px;background:var(--bg);border:1px solid var(--border);border-radius:6px;font-size:13px;gap:8px}.track-share-item span{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.agility-toolbar-save{white-space:nowrap}@media (max-width: 600px){.track-library-header{flex-direction:column;align-items:flex-start;gap:8px}.track-library-search{margin-left:0;width:100%}.track-library-search-input{width:100%}.track-grid{grid-template-columns:1fr}}.preview3d-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:400;background:#000;display:flex;flex-direction:column}.preview3d-canvas{flex:1 1 auto;min-height:0;touch-action:none}.preview3d-loading,.preview3d-empty{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;color:#fff;gap:16px;font-size:16px;text-align:center;padding:24px}.preview3d-bar{flex:0 0 auto;display:flex;flex-direction:column;gap:6px;padding:8px 14px 10px;background:rgba(0,0,0,.72);-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);border-top:1px solid rgba(255,255,255,.1)}.preview3d-bar-row{display:flex;align-items:center;gap:10px;width:100%}.preview3d-bar-left{display:flex;align-items:center;gap:8px}.preview3d-bar-center{flex:1;display:flex;align-items:center;justify-content:center;gap:10px}.preview3d-bar-right{display:flex;align-items:center;gap:8px}.preview3d-progress{width:100%;accent-color:var(--accent);cursor:pointer;margin:0}.preview3d-close{background:none;border:1px solid rgba(255,255,255,.25);border-radius:6px;color:#fff;font-size:16px;width:34px;height:34px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:background .12s}.preview3d-close:hover{background:rgba(255,255,255,.12)}.preview3d-btn{background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.22);border-radius:6px;color:#fff;font-size:13px;padding:5px 12px;height:34px;cursor:pointer;transition:background .12s;white-space:nowrap}.preview3d-btn:hover{background:rgba(255,255,255,.2)}.preview3d-btn.active{background:var(--accent);border-color:var(--accent)}.preview3d-hint{text-align:center;font-size:11px;color:#ffffff80;padding:2px 0 0;letter-spacing:.02em}.preview3d-dpad{position:absolute;bottom:110px;left:50%;transform:translate(-50%);display:grid;grid-template-columns:repeat(3,48px);grid-template-rows:repeat(3,48px);gap:4px;touch-action:none;z-index:10}.preview3d-dpad-btn{background:rgba(30,30,40,.82);border:1.5px solid rgba(255,255,255,.22);border-radius:8px;color:#fff;font-size:20px;display:flex;align-items:center;justify-content:center;cursor:pointer;user-select:none;-webkit-user-select:none;touch-action:none;transition:background .1s}.preview3d-dpad-btn:active{background:rgba(80,120,200,.72)}.preview3d-speed{width:90px;accent-color:var(--accent);cursor:pointer}.preview3d-speed-label{color:#ffffffb3;font-size:12px;min-width:28px;text-align:left}@keyframes preview3d-spin{to{transform:rotate(360deg)}}.preview3d-spinner{width:40px;height:40px;border:3px solid rgba(255,255,255,.18);border-top-color:#fff;border-radius:50%;animation:preview3d-spin .8s linear infinite}.preview3d-scrub-wrap{position:relative;width:100%;display:flex;flex-direction:column;gap:2px}.preview3d-ticks{position:absolute;top:0;left:0;right:0;pointer-events:none;height:100%}.preview3d-tick{position:absolute;transform:translate(-50%);top:50%;margin-top:-10px;width:20px;height:20px;background:none;border:none;padding:0;cursor:pointer;pointer-events:all;display:flex;flex-direction:column;align-items:center;gap:1px}.preview3d-tick:before{content:"";display:block;width:2px;height:8px;background:rgba(255,255,255,.55);border-radius:1px;transition:background .12s,height .12s}.preview3d-tick:hover:before{background:#ffffff;height:11px}.preview3d-tick-label{font-size:9px;line-height:1;color:#fff9;font-weight:600;letter-spacing:-.02em;transition:color .12s;pointer-events:none;-webkit-user-select:none;user-select:none}.preview3d-tick:hover .preview3d-tick-label{color:#fff}.preview3d-obs-counter{position:absolute;top:12px;left:50%;transform:translate(-50%);background:rgba(0,0,0,.52);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);border:1px solid rgba(255,255,255,.14);border-radius:20px;padding:4px 14px;color:#ffffffe0;font-size:13px;font-weight:500;letter-spacing:.04em;pointer-events:none;z-index:5;white-space:nowrap;transition:opacity .3s ease}.preview3d-obs-counter.hidden{opacity:0}.preview3d-speed-wrap{display:flex;align-items:center;gap:6px}.preview3d-speed-prefix{color:#ffffff8c;font-size:12px;white-space:nowrap}@media (max-width: 500px){.preview3d-speed{width:60px}.preview3d-speed-label{display:none}.preview3d-btn{padding:5px 8px;font-size:12px}.preview3d-speed-prefix{display:none}.preview3d-obs-counter{font-size:11px;padding:3px 10px;top:8px}}.hazards-hero{background:linear-gradient(135deg,var(--red) 0%,#7a1a1a 100%);color:#fff;padding:36px 24px 30px;border-radius:var(--radius);margin-bottom:20px;text-align:center;box-shadow:var(--shadow)}.hazards-hero h1{font-size:26px;font-weight:800;margin-bottom:6px}.hazards-hero p{font-size:14px;opacity:.85;max-width:480px;margin:0 auto 18px}.btn-report-hero{display:inline-flex;align-items:center;gap:8px;background:#fff;color:var(--red);font-weight:700;font-size:14px;padding:10px 22px;border-radius:8px;border:none;cursor:pointer}.btn-report-hero:hover{opacity:.92}.hazard-alert-banner{display:flex;align-items:center;gap:12px;padding:10px 14px;background:var(--card);border:1px solid var(--red);border-radius:6px;margin-bottom:12px}.hazard-alert-banner-icon{font-size:20px;flex-shrink:0}.hazard-alert-banner-body{flex:1;min-width:0}.hazard-alert-banner-title{font-weight:600;font-size:14px}.hazard-alert-banner-meta{font-size:13px;color:var(--muted)}.hazard-type-bar{display:flex;flex-wrap:wrap;gap:4px;margin-bottom:12px;border-bottom:1px solid var(--border)}.hazard-type-pill{display:inline-flex;align-items:center;gap:5px;padding:9px 12px;background:none;border:none;border-bottom:2px solid transparent;font-size:13px;font-weight:500;color:var(--muted);cursor:pointer;white-space:nowrap}.hazard-type-pill:hover:not(.active){color:var(--text)}.hazard-type-pill.active{color:var(--red);border-bottom-color:var(--red);font-weight:600}.hazard-counts-strip-wrap{position:relative;margin-bottom:16px}.hazard-counts-strip-wrap:after{content:"";position:absolute;top:0;right:0;bottom:0;width:24px;background:linear-gradient(to right,transparent,var(--bg));pointer-events:none;border-radius:0 var(--radius) var(--radius) 0}.hazard-counts-strip{display:flex;overflow-x:auto;background:var(--card);border:1px solid var(--border);border-radius:var(--radius);scrollbar-width:none}.hazard-counts-strip::-webkit-scrollbar{display:none}.hazard-count-chip{display:flex;align-items:center;gap:8px;padding:10px 14px;border:none;border-right:1px solid var(--border);background:none;color:var(--text);cursor:pointer;white-space:nowrap;flex-shrink:0;transition:background .15s}.hazard-count-chip:last-child{border-right:none}.hazard-count-chip:hover:not(.active){background:var(--hover-bg)}.hazard-count-chip.active{background:var(--red-light)}.hazard-count-chip-icon{font-size:18px}.hazard-count-chip-num{font-size:18px;font-weight:800;line-height:1}.hazard-count-chip-lbl{font-size:11px;color:var(--muted);font-weight:600;text-transform:uppercase;letter-spacing:.04em}.hazard-section-head{display:flex;align-items:center;justify-content:space-between;margin:18px 0 12px;gap:10px;flex-wrap:wrap}.hazard-section-title{font-size:16px;font-weight:700}.hazard-sort-select{padding:6px 10px;border:1px solid var(--border);border-radius:7px;font-size:13px;background:var(--bg);color:var(--text);cursor:pointer}.hazard-report-list{display:flex;flex-direction:column;gap:12px}.hazard-report-card{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow)}.hazard-report-card-head{display:flex;align-items:center;gap:12px;padding:14px 16px 10px}.hazard-report-card-icon{font-size:26px;flex-shrink:0}.hazard-report-card-meta{flex:1;min-width:0}.hazard-report-card-type{font-size:15px;font-weight:700}.hazard-report-card-loc{font-size:13px;color:var(--muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.hazard-report-card-body{padding:0 16px 14px}.hazard-report-card-desc{font-size:14px;color:var(--text);margin-bottom:8px}.hazard-report-card-footer{display:flex;align-items:center;gap:10px;font-size:12px;color:var(--muted);flex-wrap:wrap}.hazard-confirm-btn{margin-left:auto;display:inline-flex;align-items:center;gap:5px;background:none;border:1px solid var(--border);border-radius:6px;padding:5px 10px;font-size:12px;cursor:pointer;color:var(--muted);transition:all .15s}.hazard-confirm-btn:hover:not(:disabled),.hazard-confirm-btn.confirmed{background:var(--green-light);color:var(--green);border-color:var(--green)}.hazard-confirm-btn:disabled{opacity:.55;cursor:default}.hazard-dispute-btn{display:inline-flex;align-items:center;gap:5px;background:none;border:1px solid var(--border);border-radius:6px;padding:5px 10px;font-size:12px;cursor:pointer;color:var(--muted);transition:all .15s}.hazard-dispute-btn:hover,.hazard-dispute-btn.disputed{background:var(--red-light);color:var(--red);border-color:var(--red)}.hazard-mine-tag{font-size:11px;background:var(--red-light);color:var(--red);padding:1px 6px;border-radius:4px;font-weight:600}
