*,:before,:after{box-sizing:border-box}.admin-root{color:#1a1a1a;z-index:0;background:#f0f2f5;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;font-size:14px;display:flex;position:fixed;inset:0;overflow:hidden}.admin-sidebar{background:#fff;border-right:1px solid #e0e0e0;flex-direction:column;flex-shrink:0;width:210px;padding:0;display:flex;overflow-y:auto}.admin-logo{border-bottom:1px solid #e0e0e0;align-items:center;gap:10px;padding:18px 16px;display:flex}.admin-logo-icon{color:#fff;background:#e8601c;border-radius:7px;flex-shrink:0;justify-content:center;align-items:center;width:30px;height:30px;font-size:16px;display:flex}.admin-logo-text{color:#1a1a1a;font-size:13px;font-weight:600;line-height:1.2}.admin-logo-badge{color:#e8601c;letter-spacing:.04em;font-size:10px;font-weight:400;display:block}.admin-nav{flex:1;padding:10px 8px}.admin-nav-item{color:#555;cursor:pointer;text-align:left;background:0 0;border:none;border-radius:7px;align-items:center;gap:10px;width:100%;padding:9px 10px;font-size:13px;text-decoration:none;transition:background .12s;display:flex}.admin-nav-item:hover{color:#1a1a1a;background:#f5f5f5}.admin-nav-item.active{color:#e8601c;background:#fff4ee;font-weight:500}.admin-nav-item i{flex-shrink:0;font-size:17px}.admin-nav-bottom{border-top:1px solid #e0e0e0;padding:10px 8px}.admin-main{flex-direction:column;flex:1;display:flex;overflow:hidden}.admin-topbar{background:#fff;border-bottom:1px solid #e0e0e0;flex-shrink:0;align-items:center;gap:12px;height:52px;padding:0 24px;display:flex}.admin-page-title{flex:1;font-size:15px;font-weight:600}.admin-content{flex:1;padding:24px;overflow-y:auto}.admin-metrics{grid-template-columns:repeat(4,1fr);gap:14px;margin-bottom:24px;display:grid}.admin-metric{background:#fff;border:1px solid #e0e0e0;border-radius:10px;padding:16px 18px}.admin-metric-label{text-transform:uppercase;letter-spacing:.06em;color:#888;margin-bottom:8px;font-size:11px}.admin-metric-val{font-size:26px;font-weight:600;line-height:1}.admin-metric-delta{margin-top:6px;font-size:11px}.delta-up{color:#2d6a4f}.delta-down{color:#c0392b}.admin-card{background:#fff;border:1px solid #e0e0e0;border-radius:10px;padding:18px 20px}.admin-card-title{text-transform:uppercase;letter-spacing:.06em;color:#888;margin-bottom:14px;font-size:11px;font-weight:600}.admin-row-2{grid-template-columns:1fr 1fr;gap:16px;margin-bottom:16px;display:grid}.abadge{border-radius:5px;padding:2px 8px;font-size:11px;font-weight:500;display:inline-block}.abadge-green{color:#2d6a4f;background:#d8f3dc}.abadge-amber{color:#856404;background:#fff3cd}.abadge-red{color:#9b2226;background:#fde8e8}.abadge-blue{color:#1d4ed8;background:#dbeafe}.abadge-gray{color:#555;background:#f0f0f0}.admin-table-wrap{background:#fff;border:1px solid #e0e0e0;border-radius:10px;overflow:hidden}.admin-table{border-collapse:collapse;width:100%;font-size:13px}.admin-table thead th{text-align:left;text-transform:uppercase;letter-spacing:.06em;color:#888;white-space:nowrap;border-bottom:1px solid #e0e0e0;padding:12px 16px;font-size:11px;font-weight:600}.admin-table tbody tr{border-bottom:1px solid #f0f0f0;transition:background .1s}.admin-table tbody tr:last-child{border-bottom:none}.admin-table tbody tr:hover{background:#fafafa}.admin-table tbody td{vertical-align:middle;padding:11px 16px}.a-avatar{color:#1d4ed8;background:#dbeafe;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:30px;height:30px;font-size:11px;font-weight:600;display:inline-flex}.admin-btn{cursor:pointer;color:#333;background:#fff;border:1px solid #d0d0d0;border-radius:7px;align-items:center;gap:6px;padding:7px 14px;font-size:12px;font-weight:500;transition:background .12s;display:inline-flex}.admin-btn:hover{background:#f5f5f5}.admin-btn-danger{color:#c0392b;background:0 0;border-color:#c0392b}.admin-btn-danger:hover{background:#fde8e8}.admin-btn-warn{color:#856404;background:0 0;border-color:#856404}.admin-btn-warn:hover{background:#fff3cd}.admin-btn-primary{color:#fff;background:#e8601c;border-color:#e8601c}.admin-btn-primary:hover{background:#c96f05;border-color:#c96f05}.admin-filters{flex-wrap:wrap;align-items:center;gap:10px;margin-bottom:16px;display:flex}.admin-search-wrap{flex:1;min-width:200px;max-width:300px;position:relative}.admin-search-wrap i{color:#aaa;font-size:15px;position:absolute;top:50%;left:10px;transform:translateY(-50%)}.admin-search{color:#1a1a1a;background:#fff;border:1px solid #d0d0d0;border-radius:7px;width:100%;padding:8px 10px 8px 32px;font-size:13px}.admin-select{color:#1a1a1a;background:#fff;border:1px solid #d0d0d0;border-radius:7px;padding:8px 10px;font-size:13px}.admin-pagination{color:#888;align-items:center;gap:6px;margin-top:16px;font-size:12px;display:flex}.admin-page-btn{cursor:pointer;color:#333;background:#fff;border:1px solid #d0d0d0;border-radius:6px;padding:4px 10px;font-size:12px}.admin-page-btn:hover{background:#f5f5f5}.admin-page-btn.active{color:#fff;background:#e8601c;border-color:#e8601c}.admin-page-btn:disabled{opacity:.4;cursor:default}.admin-breadcrumb{color:#888;align-items:center;gap:6px;margin-bottom:16px;font-size:12px;display:flex}.admin-breadcrumb a{color:#888;cursor:pointer;text-decoration:none}.admin-breadcrumb a:hover{color:#1a1a1a}.admin-detail-header{background:#fff;border:1px solid #e0e0e0;border-radius:10px;align-items:center;gap:16px;margin-bottom:20px;padding:18px 20px;display:flex}.admin-big-avatar{color:#1d4ed8;background:#dbeafe;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:52px;height:52px;font-size:18px;font-weight:600;display:flex}.admin-detail-name{font-size:18px;font-weight:600}.admin-detail-meta{color:#888;flex-wrap:wrap;align-items:center;gap:10px;margin-top:3px;font-size:12px;display:flex}.admin-detail-actions{flex-shrink:0;gap:8px;margin-left:auto;display:flex}.admin-3col{grid-template-columns:repeat(3,1fr);gap:14px;margin-bottom:18px;display:grid}.admin-field-row{border-bottom:1px solid #f0f0f0;justify-content:space-between;align-items:center;gap:8px;padding:7px 0;font-size:13px;display:flex}.admin-field-row:last-child{border-bottom:none}.admin-field-label{color:#888;flex-shrink:0}.admin-field-val{text-align:right;font-weight:500}.admin-activity-row{border-bottom:1px solid #f0f0f0;gap:10px;padding:8px 0;font-size:12px;line-height:1.4;display:flex}.admin-activity-row:last-child{border-bottom:none}.admin-activity-time{color:#bbb;flex-shrink:0;width:56px;font-size:11px}.admin-loading{color:#888;justify-content:center;align-items:center;height:200px;font-size:13px;display:flex}.admin-error{color:#9b2226;background:#fde8e8;border:1px solid #f5c6c6;border-radius:8px;margin-bottom:16px;padding:12px 16px;font-size:13px}.admin-overlay{z-index:100;background:#00000059;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.admin-dialog{background:#fff;border-radius:12px;width:100%;max-width:380px;margin:0 16px;padding:24px 28px}.admin-dialog h3{margin-bottom:8px;font-size:16px;font-weight:600}.admin-dialog p{color:#555;margin-bottom:20px;font-size:13px;line-height:1.5}.admin-dialog-btns{justify-content:flex-end;gap:10px;display:flex}@font-face{font-family:Anton;font-style:normal;font-weight:400;font-display:swap;src:url(/fonts/anton-latin.woff2)format("woff2");unicode-range:U+??,U+131,U+152-153,U+2BB-2BC,U+2C6,U+2DA,U+2DC,U+304,U+308,U+329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}@font-face{font-family:Anton;font-style:normal;font-weight:400;font-display:swap;src:url(/fonts/anton-latin-ext.woff2)format("woff2");unicode-range:U+100-2BA,U+2BD-2C5,U+2C7-2CC,U+2CE-2D7,U+2DD-2FF,U+304,U+308,U+329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}*,:before,:after{box-sizing:border-box;margin:0;padding:0}:root{--green:#2d6a4f;--green-light:#52b788;--green-pale:#d8f3dc;--orange:#e8820c;--orange-dark:#c96f05;--bg:#f0f2f5;--card:#fff;--text:#1a1a1a;--text-muted:#666;--border:#e0e0e0;--header-h:52px;--nav-h:64px}body{background:var(--bg);color:var(--text);max-width:480px;margin:0 auto;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif}.app-shell{flex-direction:column;height:100dvh;display:flex}.app-header{height:var(--header-h);background:var(--green);color:#fff;flex-shrink:0;justify-content:flex-end;align-items:center;padding:0 1rem;display:flex;position:relative}.app-title{white-space:nowrap;font-size:1.15rem;font-weight:700;position:absolute;left:50%;transform:translate(-50%)}.header-logout{color:#fff;cursor:pointer;background:#ffffff26;border:none;border-radius:6px;padding:.3rem .7rem;font-size:.8rem}.header-right{position:relative}.header-burger{color:#fff;cursor:pointer;background:#ffffff26;border:none;border-radius:6px;padding:.3rem .7rem;font-size:1.1rem;line-height:1}.burger-menu{background:var(--card);border:1px solid var(--border);z-index:200;border-radius:12px;min-width:160px;position:absolute;top:calc(100% + 8px);right:0;overflow:hidden;box-shadow:0 4px 20px #00000026}.burger-item{text-align:left;width:100%;color:var(--text);cursor:pointer;background:0 0;border:none;padding:.75rem 1rem;font-size:.9rem;transition:background .12s;display:block}.burger-item:hover{background:var(--bg)}.burger-item--danger{color:#e74c3c}.burger-divider{background:var(--border);height:1px;margin:2px 0}.header-back{color:#fff;cursor:pointer;background:#ffffff26;border:none;border-radius:6px;padding:.3rem .7rem;font-size:.85rem}.header-back--icon{border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:36px;height:36px;padding:0;display:inline-flex}.header-back--icon:hover{background:#ffffff47}.app-main{-webkit-overflow-scrolling:touch;flex:1;overflow-y:auto}.bottom-nav{height:var(--nav-h);background:var(--card);border-top:1px solid var(--border);flex-shrink:0;display:flex}.impersonation-banner{left:50%;bottom:calc(var(--nav-h) + 12px);z-index:1200;background:var(--orange);color:#fff;border-radius:999px;align-items:center;gap:12px;max-width:calc(100% - 24px);padding:8px 10px 8px 14px;font-size:.8rem;display:flex;position:fixed;transform:translate(-50%);box-shadow:0 6px 20px #00000040}.impersonation-banner__text{white-space:nowrap;text-overflow:ellipsis;align-items:center;gap:6px;display:inline-flex;overflow:hidden}.impersonation-banner__btn{color:var(--orange-dark);cursor:pointer;background:#fffffff2;border:none;border-radius:999px;flex-shrink:0;align-items:center;gap:5px;padding:5px 12px;font-size:.78rem;font-weight:600;display:inline-flex}.impersonation-banner__btn:hover{background:#fff}.nav-item{cursor:pointer;color:var(--text-muted);background:0 0;border:none;flex-direction:column;flex:1;justify-content:center;align-items:center;gap:2px;transition:color .15s;display:flex}.nav-item.active{color:var(--green)}.nav-icon{font-size:1.3rem;line-height:1}.nav-label{font-size:.7rem;font-weight:500}.tab-content{padding:1rem}.center-msg{text-align:center;color:var(--text-muted);padding:3rem 1rem}.route-load-error{text-align:center;flex-direction:column;align-items:center;gap:1rem;padding:2.5rem 1.25rem;display:flex}.route-load-error p{color:#c0392b;background:#fdecea;border:1px solid #f5c6c0;border-radius:12px;max-width:32rem;margin:0;padding:.85rem 1rem;font-size:.9rem;line-height:1.5}.route-load-error .btn-primary{width:auto;padding:.6rem 1.4rem}.success-toast{bottom:calc(var(--nav-h) + 1rem);background:var(--green);color:#fff;z-index:500;white-space:nowrap;pointer-events:none;border-radius:24px;padding:.65rem 1.4rem;font-size:.95rem;font-weight:700;animation:.25s toast-in,.35s 1.65s forwards toast-out;position:fixed;left:50%;transform:translate(-50%);box-shadow:0 4px 20px #00000038}@keyframes toast-in{0%{opacity:0;transform:translate(-50%)translateY(12px)}to{opacity:1;transform:translate(-50%)translateY(0)}}@keyframes toast-out{0%{opacity:1;transform:translate(-50%)translateY(0)}to{opacity:0;transform:translate(-50%)translateY(12px)}}.completed-row{justify-content:space-between;align-items:center;padding:.1rem 0;display:flex}.completed-row>label:first-child{color:var(--text-muted);text-transform:uppercase;letter-spacing:.03em;font-size:.8rem;font-weight:600}.toggle-switch{cursor:pointer;flex-shrink:0;width:50px;height:28px;position:relative}.toggle-switch input{opacity:0;width:0;height:0;position:absolute}.toggle-slider{background:#e07070;border-radius:14px;transition:background .2s;position:absolute;inset:0}.toggle-slider:before{content:"";background:#fff;border-radius:50%;width:22px;height:22px;transition:transform .2s;position:absolute;top:3px;left:3px;box-shadow:0 1px 4px #00000040}.toggle-switch input:checked+.toggle-slider{background:var(--green)}.toggle-switch input:checked+.toggle-slider:before{transform:translate(22px)}.inline-field-row{justify-content:space-between;align-items:center;gap:1rem;display:flex}.inline-field-row>label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.03em;flex-shrink:0;font-size:.8rem;font-weight:600}.inline-number-input{border:1.5px solid var(--border);background:var(--card);width:90px;color:var(--text);text-align:center;border-radius:10px;flex-shrink:0;padding:.45rem .6rem;font-size:.95rem}.inline-number-input:focus{border-color:var(--green);outline:none}.inline-text-input{border:1.5px solid var(--border);background:var(--card);min-width:0;color:var(--text);border-radius:10px;flex:1;padding:.45rem .6rem;font-size:.9rem}.inline-text-input:focus{border-color:var(--green);outline:none}.inline-field-row .grade-inline-row{flex:1;justify-content:flex-end;min-width:0}.datetime-inline-row{justify-content:flex-end;align-items:center;gap:.5rem;display:flex}.datetime-inline-row input[type=date]{border:1.5px solid var(--border);background:var(--card);width:auto;color:var(--text);border-radius:10px;padding:.45rem .6rem;font-size:.9rem}.datetime-inline-row .time-input{border:1.5px solid var(--border);background:var(--card);width:110px;color:var(--text);border-radius:10px;flex-shrink:0;padding:.45rem .6rem;font-size:.9rem}.datetime-inline-row input:focus{border-color:var(--green);outline:none}.add-form{flex-direction:column;gap:.85rem;display:flex}.form-group{flex-direction:column;gap:.3rem;display:flex}.form-group label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.03em;font-size:.8rem;font-weight:600}.form-group input,.form-group select,.form-group textarea{border:1.5px solid var(--border);background:var(--card);color:var(--text);border-radius:10px;width:100%;padding:.6rem .75rem;font-family:inherit;font-size:.95rem;transition:border-color .2s}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:var(--green);outline:none}.form-group textarea{resize:vertical;min-height:70px}.toggle-group{flex-wrap:wrap;gap:.5rem;display:flex}.inline-field-row>.toggle-group--fill{flex-wrap:nowrap;flex:1;min-width:0}.inline-field-row>.toggle-group--fill>.toggle-btn{min-width:0;padding:.5rem .4rem}.grade-inline-row{align-items:center;gap:.5rem;display:flex}.grade-inline-row select{flex:1;min-width:0;width:auto!important}.grade-system-toggle{flex-shrink:0;margin:0}.grade-system-toggle .toggle-btn{padding:.3rem .55rem;font-size:.78rem}.grade-select-compact{border:1.5px solid var(--border);background:var(--card);color:var(--text);border-radius:10px;padding:.45rem .6rem;font-size:.95rem;transition:border-color .2s}.grade-select-compact:focus{border-color:var(--green);outline:none}.toggle-btn{border:1.5px solid var(--border);background:var(--card);cursor:pointer;color:var(--text-muted);white-space:normal;text-align:center;border-radius:10px;flex:1 1 0;padding:.55rem .5rem;font-size:.875rem;line-height:1.2;transition:all .15s}.toggle-btn.active{background:var(--green-pale);border-color:var(--green);color:var(--green);font-weight:600}.star-picker{gap:.4rem;display:flex}.star{cursor:pointer;color:#ddd;background:0 0;border:none;padding:0;font-size:1.6rem;line-height:1;transition:color .1s}.star.active{color:#f4a623}.btn-primary{background:var(--green);color:#fff;cursor:pointer;border:none;border-radius:12px;padding:.8rem;font-size:1rem;font-weight:600;transition:background .2s}.btn-primary:hover:not(:disabled){background:#1b4332}.btn-primary:disabled{opacity:.6;cursor:not-allowed}.btn-save{width:100%}.modal-footer{background:var(--card);border-top:1px solid var(--border);flex-shrink:0;padding:.75rem 1rem 1rem}.save-bar-sticky{background:var(--bg);border-top:1px solid var(--border);z-index:10;margin-top:.5rem;padding:.75rem 0;position:sticky;bottom:0}.route-list{padding:0}.month-header{background:var(--green);color:#fff;border-radius:12px;justify-content:space-between;align-items:center;margin:1.4rem .75rem .9rem;padding:.7rem 1rem;display:flex;box-shadow:0 2px 8px #2d6a4f40}.month-header--first{margin-top:.5rem}.month-header-name{letter-spacing:.01em;font-size:1.3rem;font-weight:800}.month-header-count{background:#fff3;border-radius:20px;padding:.2rem .7rem;font-size:.85rem;font-weight:600}.route-filters{flex-direction:column;gap:.6rem;padding:.75rem .75rem .5rem;display:flex}.route-sort-row{justify-content:flex-start;padding:0 .75rem .5rem;display:flex}.route-sort-btn{border:1.5px solid var(--border);background:var(--card);color:var(--text-muted);cursor:pointer;border-radius:20px;align-items:center;gap:.35rem;padding:.3rem .7rem;font-size:.78rem;font-weight:500;transition:all .15s;display:inline-flex}.route-sort-btn:hover{color:var(--text);border-color:var(--green)}.date-filter-row{flex-wrap:wrap;align-items:flex-end;gap:.6rem;display:flex}.date-filter-field{flex-direction:column;flex:1;gap:.2rem;min-width:0;display:flex}.date-filter-field span{color:var(--text-muted);text-transform:uppercase;letter-spacing:.03em;font-size:.72rem;font-weight:600}.date-filter-input{border:1.5px solid var(--border);background:var(--card);color:var(--text);border-radius:10px;width:100%;padding:.5rem .6rem;font-size:.9rem}.date-filter-input:focus{border-color:var(--green);outline:none}.date-filter-warning{color:#c0392b;background:#fdecea;border-radius:8px;padding:.4rem .6rem;font-size:.8rem}.grade-filter-row{flex-wrap:wrap;gap:.35rem;display:flex}.grade-filter-btn{border:1.5px solid var(--border);background:var(--bg);cursor:pointer;color:var(--text-muted);border-radius:20px;padding:.25rem .6rem;font-size:.75rem;font-weight:500;transition:all .15s}.grade-filter-btn.active{background:var(--green);border-color:var(--green);color:#fff;font-weight:600}.day-group{margin:0 .75rem 1.4rem}.day-head{align-items:center;gap:.75rem;padding:.25rem .25rem .7rem;display:flex}.day-date-box{text-align:center;background:var(--green);color:#fff;border-radius:12px;flex-shrink:0;width:50px;padding:.45rem 0 .4rem;line-height:1}.day-date-dd{font-size:1.45rem;font-weight:800}.day-date-mon{text-transform:uppercase;opacity:.9;letter-spacing:.05em;margin-top:.2rem;font-size:.7rem;font-weight:600}.day-head-meta{flex:1;min-width:0}.day-weekday{color:var(--text);font-size:1.1rem;font-weight:700}.day-env{color:var(--text-muted);font-size:.95rem;font-weight:600}.day-today-tag{background:var(--green-light);color:#fff;vertical-align:middle;border-radius:20px;margin-left:.5rem;padding:.1rem .55rem;font-size:.72rem;font-weight:700}.day-sub{color:var(--text);margin-top:.25rem;font-size:.95rem;font-weight:700}.day-stats{text-align:right;flex-shrink:0}.day-stats-big{color:var(--green);font-size:1.3rem;font-weight:800;line-height:1}.day-stats-lbl{color:var(--text-muted);font-size:.74rem;font-weight:600}.route-session{margin-bottom:.75rem}.session-head{background:#eef1f4;border-radius:10px;align-items:center;gap:.55rem;margin-bottom:.5rem;padding:.5rem .75rem;display:flex}.session-env{flex-shrink:0;font-size:1.05rem}.session-loc{color:var(--text);white-space:nowrap;text-overflow:ellipsis;font-size:.95rem;font-weight:700;overflow:hidden}.session-count{color:var(--text-muted);flex-shrink:0;margin-left:auto;font-size:.82rem;font-weight:600}.day-routes{border-left:2px dashed #cdd3d9;flex-direction:column;gap:.5rem;margin-left:.9rem;padding-left:.5rem;display:flex}.route-card{background:var(--card);border-left:6px solid var(--green-light);border-right:6px solid var(--green-light);border-radius:12px;padding:.75rem .85rem;position:relative;box-shadow:0 1px 6px #14281e0f}.route-card.attempted{border-left-color:#e07070;border-right-color:#e07070}.route-card-top{align-items:center;gap:.75rem;display:flex}.route-grade-box{text-align:center;min-width:54px;color:var(--text);background:#ffffffb3;border:1.5px solid #0000002e;border-radius:10px;flex-shrink:0;padding:.4rem .6rem;font-size:1.35rem;font-weight:800;line-height:1}.route-card-mid{flex:1;min-width:0}.route-grade{color:var(--text);white-space:nowrap;align-items:baseline;gap:3px;font-weight:800;display:flex}.route-grade-system{color:var(--text);letter-spacing:.02em;font-size:.75rem;font-weight:600}.route-type{color:var(--text);white-space:nowrap;text-overflow:ellipsis;font-size:.98rem;font-weight:600;overflow:hidden}.route-time{color:#2a2f34;margin-top:.2rem;font-size:.88rem;font-weight:500}.route-name{color:var(--text);margin-top:.6rem;font-size:1.05rem;font-weight:700;line-height:1.3}.route-card-actions{flex-shrink:0;gap:.4rem;display:flex}.icon-btn{color:#2a2f34;cursor:pointer;background:#ffffffd9;border:none;border-radius:9px;justify-content:center;align-items:center;width:34px;height:34px;transition:opacity .15s;display:flex;box-shadow:0 1px 2px #0000001a}.icon-btn:hover{opacity:.7}.icon-btn svg{width:18px;height:18px;display:block}.route-card-badges{flex-wrap:wrap;gap:.45rem;margin-top:.6rem;display:flex}.badge{color:#2a2f34;white-space:nowrap;background:#ffffffd9;border-radius:7px;padding:.18rem .55rem;font-size:.82rem;font-weight:600}.badge-attempted{color:#c0392b;background:#fdecea}.badge-stars{color:#d99100;background:#fff8e1}.badge-attempts{color:#2178c4;background:#e8f4ff}.badge-flash{color:#c77700;background:#fff3cd;font-weight:700}.badge-tag{color:#2a2f34;background:#ffffffeb;border:1px solid #0000001a}.location-input-wrap{position:relative}.location-input-wrap input{width:100%}.location-input-wrap.inline-text-input{flex:1;min-width:0}.location-input-wrap.inline-text-input input{border-radius:10px;padding:.45rem .6rem;font-size:.9rem}.location-dropdown{background:var(--card);border:1.5px solid var(--border);z-index:50;border-radius:10px;max-height:180px;position:absolute;top:calc(100% + 4px);left:0;right:0;overflow-y:auto;box-shadow:0 4px 16px #0000001f}.location-option{text-align:left;width:100%;color:var(--text);cursor:pointer;border:none;border-bottom:1px solid var(--border);background:0 0;padding:.6rem .9rem;font-size:.875rem;display:block}.location-option:last-child{border-bottom:none}.location-option:hover{background:var(--bg)}.route-location{color:var(--text);white-space:nowrap;text-overflow:ellipsis;margin-top:.2rem;font-size:.78rem;overflow:hidden}.route-notes{color:var(--text);background:#fff9;border-radius:8px;margin-top:.5rem;padding:.45rem .6rem;font-size:.92rem;font-style:italic;line-height:1.4}.route-added-by{color:#1d4ed8;background:#e8f0ff;border-radius:7px;margin-top:.6rem;padding:.3rem .55rem;font-size:.82rem;display:inline-block}.route-added-by--mine{color:var(--text-muted)}.route-added-by--mine span{font-style:italic}.stats-page{flex-direction:column;gap:.5rem;padding-bottom:1.5rem;display:flex}.stats-grid{grid-template-columns:1fr 1fr 1fr;gap:.6rem;display:grid}.stats-grid .stat-card:nth-child(3n-1):last-child,.stats-grid .stat-card:nth-child(3n):last-child{grid-column:span 1}.stats-grid:has(.stat-card:nth-child(5):last-child){grid-template-columns:1fr 1fr 1fr}.stats-grid:has(.stat-card:nth-child(5):last-child) .stat-card:nth-child(4){grid-column:1/span 2}.stats-grid:has(.stat-card:nth-child(5):last-child) .stat-card:nth-child(5){grid-column:3}.stat-card{background:var(--card);text-align:center;border:1.5px solid var(--border);border-radius:12px;padding:.75rem .5rem;position:relative}.stat-icon{font-size:1rem;line-height:1;position:absolute;top:.5rem;left:.5rem}.stat-card.accent{border-color:var(--green);background:var(--green-pale)}.top-grades-card{flex-direction:column;justify-content:center;align-items:center;gap:.25rem;display:flex}.top-grades-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.03em;font-size:.68rem;font-weight:600}.top-grades-values{flex-wrap:wrap;justify-content:center;align-items:center;gap:.25rem;display:flex}.top-grade-item{align-items:baseline;gap:.15rem;display:flex}.top-grade-name{color:var(--green);font-size:1rem;font-weight:800}.top-grade-count{color:var(--text-muted);font-size:.62rem}.top-grade-sep{color:var(--border);margin:0 .1rem;font-size:.75rem}.stat-value{color:var(--green);font-size:1.4rem;font-weight:800;line-height:1}.stat-label{color:var(--text-muted);text-transform:uppercase;margin-top:.2rem;font-size:.68rem;font-weight:600}.stat-sub{color:var(--text-muted);font-size:.65rem}.perf-card{background:var(--card);border:1.5px solid var(--border);border-radius:12px;flex-direction:column;gap:.85rem;padding:.75rem .85rem;display:flex}.perf-section+.perf-section{border-top:1px solid var(--border);padding-top:.75rem}.perf-section-title{color:var(--text-muted);text-transform:uppercase;letter-spacing:.04em;justify-content:center;align-items:center;gap:.35rem;margin-bottom:.5rem;font-size:.85rem;font-weight:700;display:flex}.perf-table{border-collapse:collapse;width:100%}.perf-table tr+tr td,.perf-table tr+tr th{border-top:1px solid var(--border)}.perf-row-label{text-align:left;color:var(--text);white-space:nowrap;width:1%;padding:.4rem 0;font-size:.82rem;font-weight:600}.perf-row-value{text-align:right;white-space:nowrap;padding:.4rem 0}.perf-grade{align-items:baseline;gap:.18rem;margin-left:.6rem;display:inline-flex}.perf-grade:first-child{margin-left:0}.perf-grade-name{color:var(--green);font-size:1rem;font-weight:800}.perf-grade-count{color:var(--text-muted);font-size:.62rem}.perf-num-cell{text-align:right;white-space:nowrap;padding:.4rem 0}.perf-num-cell--left{text-align:left;white-space:nowrap;width:1%;padding-left:.75rem}.perf-table--hardest .perf-row-label{width:100%}.perf-grade-num{color:var(--green);font-size:1.05rem;font-weight:800}.perf-grade-label-cell{text-align:left;width:1%;color:var(--text-muted);white-space:nowrap;padding:.4rem 0 .4rem .5rem;font-size:.8rem}.perf-na{color:var(--text-muted);font-weight:700}.perf-empty{color:var(--text-muted);font-size:.8rem}.info-i{cursor:pointer;background:var(--orange);color:#fff;text-transform:none;letter-spacing:normal;border:none;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:16px;height:16px;padding:0;font-family:Georgia,Times New Roman,serif;font-size:.72rem;font-style:italic;font-weight:800;line-height:1;display:inline-flex}.info-i:hover{background:var(--orange-dark)}.info-modal-backdrop{z-index:300;background:#00000073;justify-content:center;align-items:center;padding:1rem;display:flex;position:fixed;inset:0}.info-modal-dialog{background:var(--card);text-transform:none;letter-spacing:normal;border-radius:16px;width:min(340px,92vw);max-height:80dvh;padding:1.1rem 1.1rem 1.2rem;font-weight:400;position:relative;overflow-y:auto}.info-modal-close{cursor:pointer;color:var(--text-muted);background:0 0;border:none;padding:.1rem .3rem;font-size:1rem;position:absolute;top:.7rem;right:.8rem}.info-modal-title{color:var(--text);margin-bottom:.55rem;padding-right:1.5rem;font-size:1rem;font-weight:700}.info-modal-body{color:var(--text);font-size:.85rem;line-height:1.45}.chart-section{background:var(--card);border-radius:12px;padding:.75rem}.chart-section h3{color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;margin-bottom:.5rem;font-size:.85rem;font-weight:700}.chart-legend{color:var(--text-muted);justify-content:center;gap:1rem;margin-top:.5rem;font-size:.78rem;display:flex}.dot{border-radius:50%;width:10px;height:10px;margin-right:4px;display:inline-block}.month-table{flex-direction:column;gap:.25rem;display:flex}.month-row{align-items:center;gap:.5rem;display:flex}.month-name{flex-shrink:0;width:48px;font-size:.78rem;font-weight:600}.month-bar-wrap{background:var(--bg);border-radius:6px;flex:1;height:22px;overflow:hidden}.bar-tooltip-wrap{height:22px}.month-bar-split{border-radius:6px;height:22px;transition:width .4s;display:flex;overflow:hidden}.month-bar-boulder{background:#1b4332;justify-content:center;align-items:center;min-width:0;height:22px;display:flex;overflow:hidden}.month-bar-rope{background:#2d6a4f;justify-content:center;align-items:center;min-width:0;height:22px;display:flex;overflow:hidden}.month-bar-multi{background:#52b788;justify-content:center;align-items:center;min-width:0;height:22px;display:flex;overflow:hidden}.month-bar-boulder span,.month-bar-rope span,.month-bar-multi span{color:#fff;white-space:nowrap;padding:0 3px;font-size:.7rem;font-weight:700}.month-bar-legend{flex-wrap:wrap;gap:14px;margin-bottom:10px;display:flex}.legend-item{color:var(--text-muted);align-items:center;gap:5px;font-size:.75rem;display:flex}.legend-dot{border-radius:2px;flex-shrink:0;width:10px;height:10px}.legend-item--boulder .legend-dot{background:#1b4332}.legend-item--rope .legend-dot{background:#2d6a4f}.legend-item--multi .legend-dot{background:#52b788}.month-total-label{color:var(--text-muted);text-align:right;flex-shrink:0;width:28px;font-size:.78rem;font-weight:700}.auth-container{background-color:#0000;background-image:radial-gradient(120% 80% at 50% -10%,#52b78873 0%,#52b78800 55%),linear-gradient(160deg,#1b4332 0%,#2d6a4f 45%,#40916c 100%);background-position:0 0,0 0;background-repeat:repeat,repeat;background-size:auto,auto;background-attachment:fixed;background-origin:padding-box,padding-box;background-clip:border-box,border-box;justify-content:center;align-items:center;min-height:100dvh;padding:1.25rem;display:flex}.auth-card{background:#fff;border-radius:24px;width:100%;max-width:400px;padding:2.25rem 1.75rem 2rem;animation:.45s cubic-bezier(.2,.8,.25,1) both auth-rise;position:relative;box-shadow:inset 0 1px #ffffff80,0 20px 50px -12px #0d281c73,0 6px 16px -8px #0d281c4d}@keyframes auth-rise{0%{opacity:0;transform:translateY(14px)scale(.985)}to{opacity:1;transform:translateY(0)scale(1)}}.auth-card--center{text-align:center}.verify-hint{background:var(--green-pale);border:1px solid #b7e4c7;border-radius:12px;margin:.75rem 0;padding:.75rem 1rem;font-size:.875rem}.btn-sm{margin-top:.5rem;padding:.3rem .75rem;font-size:.8rem}.auth-logo{object-fit:cover;border-radius:18px;width:68px;height:68px;margin:0 auto .85rem;display:block;box-shadow:0 10px 22px -8px #e11d4380}.auth-card h1{letter-spacing:.02em;text-transform:uppercase;text-align:center;background:linear-gradient(100deg,#1b4332 0%,#2d6a4f 50%,#40916c 100%);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;margin-bottom:.35rem;font-family:Anton,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;font-size:1.95rem;font-weight:400;line-height:1.05}.auth-card h2{color:var(--text);text-align:center;margin-bottom:1.5rem;font-size:1.05rem;font-weight:600}.auth-card .form-group{margin-top:1.1rem}.auth-card .form-group label{font-size:.72rem}.auth-card .form-group input,.auth-card .form-group select{background:#f1f4f6;border:1.5px solid #0000;border-radius:12px;padding:.75rem .9rem}.auth-card .form-group input:focus,.auth-card .form-group select:focus{border-color:var(--green-light);background:#fff;box-shadow:0 0 0 4px #52b7882e}.auth-card .btn-primary{letter-spacing:.01em;background:linear-gradient(135deg,#52b788 0%,#2d6a4f 100%);border-radius:14px;margin-top:1.75rem;padding:.85rem;font-weight:700;transition:transform .15s,box-shadow .15s,filter .15s;box-shadow:0 10px 22px -8px #2d6a4fa6}.auth-card .btn-primary:hover:not(:disabled){filter:brightness(1.04);background:linear-gradient(135deg,#52b788 0%,#2d6a4f 100%);transform:translateY(-1px);box-shadow:0 14px 26px -8px #2d6a4fb3}.auth-card .btn-primary:active:not(:disabled){transform:translateY(0);box-shadow:0 6px 14px -8px #2d6a4f99}.auth-lang-switcher{background:#f1f4f6;border-radius:10px;gap:0;margin:0;padding:3px;display:inline-flex;position:absolute;top:1.1rem;right:1.1rem}.auth-lang-btn{cursor:pointer;color:var(--text-muted);background:0 0;border:none;border-radius:8px;padding:.28rem .6rem;font-size:.76rem;font-weight:700;transition:all .18s}.auth-lang-btn.active{color:#fff;background:var(--green);box-shadow:0 2px 6px -2px #2d6a4f99}.form-row{gap:.75rem;display:flex}.form-row .form-group{flex:1}.btn-secondary{color:var(--green);border:1.5px solid var(--green);cursor:pointer;background:0 0;border-radius:10px;padding:.45rem 1rem;font-size:.875rem;font-weight:600;transition:all .18s}.btn-secondary:hover{background:var(--green-pale)}.error-message{color:#c0392b;background:#fdecea;border:1px solid #f5c6c0;border-radius:10px;margin:.5rem 0 0;padding:.6rem .85rem;font-size:.875rem}.auth-link{text-align:center;color:var(--text-muted);margin-top:1.5rem;font-size:.875rem}.auth-link a{color:var(--green);font-weight:700;text-decoration:none}.auth-link a:hover{text-decoration:underline}.auth-password-row{justify-content:flex-end;margin-top:.5rem;display:flex}.auth-forgot-link{color:var(--text-muted);font-size:.8rem;font-weight:500;text-decoration:none}.auth-forgot-link:hover{color:var(--green)}.auth-remember-row{margin-top:.9rem}.auth-remember-label{color:var(--text);cursor:pointer;align-items:center;gap:.5rem;font-size:.875rem;display:flex}.auth-remember-label input[type=checkbox]{cursor:pointer;width:16px;height:16px;accent-color:var(--green)}.auth-hint{color:var(--text-muted);text-align:center;margin-bottom:.75rem;font-size:.875rem;line-height:1.5}.auth-info-msg{color:var(--text);background:var(--green-pale,#f0faf4);border:1px solid #b7e4c7;border-radius:12px;padding:.85rem 1rem;font-size:.875rem;line-height:1.5}.auth-divider{color:#111;text-transform:uppercase;letter-spacing:.1em;align-items:center;gap:.75rem;margin:1.5rem 0;font-size:.82rem;font-weight:700;display:flex}.auth-divider:before,.auth-divider:after{content:"";opacity:.2;background:#111;flex:1;height:1.5px}.google-btn{color:#222;cursor:pointer;background:#fff;border:2px solid #222;border-radius:8px;justify-content:center;align-items:center;gap:10px;width:100%;padding:13px 20px;font-size:15px;transition:background .15s;display:flex}.google-btn:hover{background:#f5f5f5}.google-btn:disabled{opacity:.6;cursor:default}.type-switcher{flex-wrap:wrap;gap:.4rem;margin-top:1.25rem;margin-bottom:.4rem;display:flex}.type-tab{border:1.5px solid var(--border);background:var(--bg);cursor:pointer;color:var(--text-muted);border-radius:20px;padding:.35rem .75rem;font-size:.8rem;transition:all .15s}.type-tab.active{background:var(--green-pale);border-color:var(--green);color:var(--green);font-weight:600}.grade-months{flex-direction:column;gap:.75rem;display:flex}.grade-month-label{color:var(--text);text-transform:uppercase;letter-spacing:.06em;border-bottom:2px solid var(--green-light);margin-bottom:.4rem;padding-bottom:.3rem;font-size:.9rem;font-weight:800}.grade-rows{flex-direction:column;gap:.3rem;display:flex}.grade-row{align-items:center;gap:.5rem;display:flex}.grade-tag{color:var(--green);flex-shrink:0;width:36px;font-size:.8rem;font-weight:700}.grade-count{color:var(--text-muted);text-align:right;flex-shrink:0;width:24px;margin-left:-.25rem;font-size:.8rem;font-weight:600}.grade-bar-wrap{background:var(--bg);border-radius:8px;flex:1;height:16px;overflow:hidden}.grade-bar-fill{background:linear-gradient(90deg, var(--green), var(--green-light));border-radius:8px;height:100%;transition:width .3s}.grade-tag--unknown{color:var(--text-muted)}.grade-bar-fill--unknown{background:linear-gradient(90deg, var(--text-muted), #aaa)}.grade-month-total{border-top:1px dashed var(--border);color:var(--text-muted);text-align:right;margin-top:.5rem;padding-top:.4rem;font-size:.78rem}.grade-month-total strong{color:var(--green);font-size:.85rem}.no-data-msg{color:var(--text-muted);text-align:center;padding:1rem 0;font-size:.85rem}.grade-owner-label{letter-spacing:.01em;margin:.5rem 0 .35rem;font-size:.95rem;font-weight:800}.grade-multi-group{border-top:1px solid var(--border);align-items:flex-start;gap:.5rem;padding:.3rem 0;display:flex}.grade-multi-group:first-child,.grade-rows--single .grade-multi-group{border-top:none}.grade-multi-tag{flex-shrink:0;min-width:2.6rem;padding-top:.15rem;font-weight:800}.grade-multi-persons{flex-direction:column;flex:1;gap:.15rem;min-width:0;display:flex}.grade-multi-persons .grade-row{gap:.4rem}.grade-person-name{white-space:nowrap;text-overflow:ellipsis;flex-shrink:0;min-width:4.5rem;font-size:.78rem;font-weight:700;overflow:hidden}.grade-month-totals{flex-wrap:wrap;gap:.75rem;margin-top:.4rem;font-size:.88rem;font-weight:700;display:flex}.grade-month-totals strong{font-weight:800}.grade-friend-block{border-top:1px dashed var(--border);margin-top:.4rem;padding-top:.4rem}.heatmap-section{flex-direction:column;gap:.75rem;display:flex}.heatmap-type-switcher{flex-wrap:wrap;gap:.4rem;display:flex}.heatmap-scroll-wrap{-webkit-overflow-scrolling:touch;overflow-x:auto}.heatmap-table{border-collapse:collapse;min-width:max-content;font-size:.78rem}.heatmap-grade-col{width:36px}.heatmap-month-head{color:var(--text-muted);text-align:center;white-space:nowrap;min-width:30px;padding:.25rem .2rem;font-size:.65rem;font-weight:700}.heatmap-grade-label{color:var(--green);white-space:nowrap;text-align:left;padding:.25rem .4rem .25rem 0;font-size:.78rem;font-weight:700}.heatmap-cell{text-align:center;border-radius:5px;min-width:30px;height:28px;padding:.25rem .15rem;font-size:.72rem;font-weight:600}.heatmap-empty{color:#ccc;font-weight:400}.heat-0{background:0 0}.heat-1{color:#2d6a4f;background:#d8f3dc}.heat-2{color:#1b4332;background:#95d5a5}.heat-3{color:#fff;background:#52b788}.heat-4{color:#fff;background:#2d6a4f}.heat-5{color:#d8f3dc;background:#1b4332}.heatmap-legend{color:var(--text-muted);align-items:center;gap:.3rem;font-size:.72rem;display:flex}.heatmap-legend-cell{border-radius:3px;width:16px;height:16px;display:inline-block}.heatmap-legend-label{font-size:.7rem}.pyramid-section{background:var(--card);border-radius:12px;flex-direction:column;gap:.75rem;padding:1rem;display:flex}.pyramid-header{align-items:center;gap:.5rem;display:flex}.pyramid-header h3{text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);flex:1;font-size:.82rem;font-weight:700}.pyramid-info-btn{color:var(--green);cursor:pointer;background:0 0;border:none;border-radius:50%;padding:.1rem .25rem;font-size:1.25rem;font-weight:900;line-height:1;transition:opacity .15s}.pyramid-info-btn:hover{opacity:.7}.pyramid-person-switcher{flex-wrap:wrap;gap:.4rem;display:flex}.pyramid-person-btn{border:1.5px solid var(--border);background:var(--bg);color:var(--text-muted);cursor:pointer;border-radius:20px;padding:.3rem .75rem;font-size:.82rem;font-weight:600;transition:all .15s}.pyramid-person-btn.active{background:var(--green-pale);border-color:var(--green);color:var(--green)}.pyramid-bars{flex-direction:column;gap:5px;display:flex}.pyramid-row{align-items:center;gap:8px;display:flex}.pyramid-grade{text-align:left;width:36px;color:var(--green);flex-shrink:0;font-size:.78rem;font-weight:700}.pyramid-bar-wrap{flex:1}.pyramid-bar{background:var(--green);border-radius:0 6px 6px 0;justify-content:flex-end;align-items:center;min-width:28px;height:24px;padding-right:7px;transition:width .35s;display:flex}.pyramid-bar-count{color:#fff;font-size:.75rem;font-weight:700}.pyramid-analysis{border-left:4px solid;border-radius:8px;align-items:flex-start;gap:.6rem;padding:.65rem .75rem;font-size:.82rem;line-height:1.5;display:flex}.pyramid-analysis-icon{flex-shrink:0;margin-top:1px;font-size:1.1rem}.pyramid-analysis-title{margin-bottom:.15rem;font-weight:700}.pyramid-analysis-text{opacity:.9}.pyramid-modal-backdrop{z-index:200;background:#00000073;justify-content:center;align-items:center;padding:1.25rem;display:flex;position:fixed;inset:0}.pyramid-modal{background:var(--card);border-radius:16px;width:100%;max-width:420px;max-height:80dvh;overflow-y:auto}.pyramid-modal-header{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:1rem 1rem .5rem;display:flex}.pyramid-modal-title{font-size:.95rem;font-weight:700}.pyramid-modal-close{color:var(--text-muted);cursor:pointer;background:0 0;border:none;padding:.25rem;font-size:1rem}.pyramid-modal-body{flex-direction:column;gap:.75rem;padding:1rem;display:flex}.pyramid-modal-text{color:var(--text);font-size:.86rem;line-height:1.55}.pyramid-modal-note{background:var(--green-pale);color:var(--green);border-radius:8px;padding:.75rem;font-size:.82rem;line-height:1.5}.pyramid-example{flex-direction:column;gap:4px;margin:.25rem 0;display:flex}.pyramid-example-row{align-items:center;gap:6px;display:flex}.pyramid-ex-grade{text-align:right;width:32px;color:var(--green);flex-shrink:0;font-size:.75rem;font-weight:700}.pyramid-ex-bar-wrap{flex:1}.pyramid-ex-bar{background:var(--green);border-radius:0 5px 5px 0;justify-content:flex-end;align-items:center;min-width:24px;height:20px;padding-right:6px;display:flex}.pyramid-ex-bar span{color:#fff;font-size:.7rem;font-weight:700}.stats-empty-state{background:var(--card);border-radius:12px;flex-direction:column;gap:.6rem;padding:1.5rem 1.25rem;display:flex}.stats-empty-icon{font-size:2rem}.stats-empty-title{color:var(--text);font-size:1rem;font-weight:800}.stats-empty-text{color:var(--text-muted);font-size:.875rem;line-height:1.5}.stats-empty-list{flex-direction:column;gap:.5rem;padding:.25rem 0;list-style:none;display:flex}.stats-empty-list li{color:var(--text);font-size:.85rem;line-height:1.5}.stats-empty-hint{color:var(--text-muted);font-size:.8rem}.compare-empty-cta{background:var(--green);color:#fff;cursor:pointer;border:none;border-radius:10px;align-self:flex-start;margin-top:.5rem;padding:.65rem 1.25rem;font-size:.9rem;font-weight:700;transition:background .15s,box-shadow .15s;box-shadow:0 3px 10px #2d6a4f4d}.compare-empty-cta:hover{background:var(--green-light)}.celebration-backdrop{z-index:300;background:#0000008c;justify-content:center;align-items:center;padding:1.5rem;display:flex;position:fixed;inset:0}.celebration-modal{background:var(--card);text-align:center;border-radius:20px;flex-direction:column;align-items:center;gap:.6rem;width:100%;max-width:340px;padding:2rem 1.5rem;display:flex;box-shadow:0 8px 40px #00000040}.celebration-climbers{letter-spacing:.25rem;font-size:2.5rem}.celebration-title{color:var(--text);font-size:1.4rem;font-weight:800}.celebration-grade{color:var(--green);font-size:3rem;font-weight:900;line-height:1}.celebration-type{color:var(--text-muted);font-size:.9rem;font-weight:600}.celebration-text{color:var(--text);font-size:.9rem;line-height:1.5}.celebration-btn{width:100%;margin-top:.5rem}.celebration-btns{flex-direction:column;gap:.5rem;width:100%;margin-top:.5rem;display:flex}.celebration-btn-accept{width:100%}.celebration-btn-close{border:1.5px solid var(--border);width:100%;color:var(--text-muted);cursor:pointer;background:0 0;border-radius:10px;padding:.7rem;font-size:.9rem;font-weight:600}.milestones-list{flex-direction:column;gap:.5rem;display:flex}.milestone-item{background:var(--bg);border-left:4px solid var(--green);border-radius:10px;align-items:center;gap:.75rem;padding:.6rem .75rem;display:flex}.milestone-icon{border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:36px;height:36px;font-size:1.1rem;display:flex}.milestone-body{flex:1;min-width:0}.milestone-label{color:var(--text);font-size:.88rem;font-weight:700}.milestone-meta{flex-wrap:wrap;align-items:center;gap:.5rem;margin-top:.1rem;display:flex}.milestone-sublabel{font-size:.72rem;font-weight:700}.milestone-date{color:var(--text-muted);font-size:.72rem}.milestones-empty{text-align:center;color:var(--text-muted);padding:1.5rem 0}.milestones-empty-icon{margin-bottom:.5rem;font-size:2rem}.milestones-empty p{font-size:.88rem}.milestones-empty-sub{opacity:.75;margin-top:.25rem;font-size:.78rem}.onboarding-perf{text-align:center;flex-direction:column;align-items:center;gap:.75rem;padding:1.5rem 1rem 2rem;display:flex}.onboarding-perf-icon{font-size:2.5rem}.onboarding-perf-title{color:var(--text);font-size:1.15rem;font-weight:800}.onboarding-perf-text{color:var(--text);max-width:320px;font-size:.9rem;line-height:1.5}.onboarding-perf-subtext{color:var(--text-muted);font-size:.82rem}.onboarding-perf-hint{color:var(--text-muted);font-size:.8rem}.onboarding-perf-btn{width:100%;max-width:280px;margin-top:.5rem}.onboarding-previews{flex-direction:column;gap:.75rem;width:100%;display:flex}.onboarding-preview-card{background:var(--card);text-align:left;border:1.5px solid var(--border);opacity:.85;border-radius:12px;padding:.75rem}.onboarding-preview-label{text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);margin-bottom:.4rem;font-size:.72rem;font-weight:700}.onboarding-demo-heatmap{overflow-x:auto}.perf-curve-section{flex-direction:column;gap:.75rem;display:flex}.perf-info{color:var(--text-muted);text-align:center;flex-direction:column;align-items:center;gap:4px;padding:.1rem 0 .25rem;font-size:.75rem;display:flex}.perf-type-legend{flex-wrap:wrap;justify-content:center;gap:12px;display:flex}.perf-type-legend-item{align-items:center;gap:4px;font-size:.72rem;font-weight:600;display:flex}.perf-type-legend-dot{border-radius:50%;flex-shrink:0;width:8px;height:8px}.perf-loading{color:var(--text-muted);text-align:center;padding:1rem 0;font-size:.85rem}.perf-tooltip{background:var(--card);border:1.5px solid var(--border);border-radius:8px;padding:.5rem .75rem;font-size:.82rem;box-shadow:0 2px 8px #0000001a}.perf-tooltip-label{color:var(--text);margin-bottom:.3rem;font-weight:700}.perf-tooltip-row{align-items:center;gap:.4rem;font-weight:600;display:flex}.perf-tooltip-grade{font-size:1rem;font-weight:800}.perf-tooltip-count{color:var(--text-muted);font-size:.72rem;font-weight:400}.settings-page{flex-direction:column;gap:1rem;padding-bottom:2rem;display:flex}.settings-section{background:var(--card);border-radius:12px;flex-direction:column;gap:.75rem;padding:1rem;display:flex}.settings-section-title{color:var(--text);align-items:center;gap:.4rem;margin-bottom:.25rem;font-size:.9rem;font-weight:700;display:flex}.settings-collapse-btn{cursor:pointer;color:var(--text-muted,#888);background:0 0;border:none;margin-left:auto;padding:0 .2rem;font-size:1rem;line-height:1}.settings-save-bar{margin-top:.25rem}.success-msg{color:var(--green);margin-bottom:.4rem;font-size:.85rem;font-weight:600}.settings-hint{color:var(--text-muted);margin-bottom:.25rem;font-size:.8rem}.settings-grade-block{border-top:1px solid var(--border);padding:.5rem 0}.settings-grade-label{color:var(--green);margin-bottom:.4rem;font-size:.8rem;font-weight:700}.settings-grade-row{gap:.75rem;display:flex}.settings-grade-row .form-group{flex:1}.friend-type-hint{flex-wrap:wrap;align-items:center;gap:.4rem;margin:.1rem 0;font-size:.82rem;font-weight:600;display:flex}.friend-type-hint-btn{cursor:pointer;background:0 0;border:1.5px solid;border-radius:8px;padding:.15rem .5rem;font-size:.8rem;font-weight:700}.sound-row{align-items:center;gap:.6rem;display:flex}.sound-icon{text-align:center;flex-shrink:0;width:1.5rem;font-size:1.25rem}.sound-slider{height:4px;accent-color:var(--green);cursor:pointer;flex:1}.sound-label{color:var(--text-muted);text-align:right;flex-shrink:0;width:52px;font-size:.8rem;font-weight:600}.sound-preview-btn{border:1.5px solid var(--green);background:var(--green-pale);color:var(--green);cursor:pointer;white-space:nowrap;border-radius:8px;flex-shrink:0;padding:.3rem .7rem;font-size:.8rem;font-weight:700}.sound-preview-btn:disabled{opacity:.4;cursor:not-allowed}.export-csv-block{border-bottom:1px solid var(--border);flex-direction:column;gap:.5rem;margin-bottom:.25rem;padding-bottom:.75rem;display:flex}.export-btn-row{gap:.6rem;display:flex}.btn-export{border:1.5px solid var(--green);background:var(--green-pale);color:var(--green);cursor:pointer;border-radius:10px;flex:1;padding:.6rem .75rem;font-size:.9rem;font-weight:700;transition:background .15s}.btn-export:hover{background:#c7ebd1}.btn-export:disabled{opacity:.5;cursor:not-allowed}.btn-export--xlsx{color:#2e7d32;background:#e8f5e9;border-color:#388e3c}.btn-export--xlsx:hover{background:#d4edda}.btn-import{cursor:pointer;justify-content:center;align-items:center;margin-top:.5rem;display:inline-flex}.btn-import.is-loading{opacity:.5;pointer-events:none}.import-report{color:var(--text);margin-top:.6rem;font-size:.85rem}.import-report-error{color:#c62828}.color-picker{flex-wrap:wrap;gap:.5rem;display:flex}.color-dot{cursor:pointer;border-radius:50%;width:28px;height:28px;transition:transform .12s,outline .12s}.color-dot:hover,.color-dot.selected{transform:scale(1.15)}.route-time{color:var(--text-muted);opacity:.75;margin-left:.3rem;font-size:.68rem}.route-color-grip{filter:drop-shadow(0 1px 2px #00000059);flex-shrink:0;align-self:center;width:13px;height:21px;display:block}.target-selector{flex-wrap:wrap;gap:.4rem;display:flex}.target-chip{border:1.5px solid var(--border);background:var(--bg);cursor:pointer;color:var(--text-muted);border-radius:20px;padding:.4rem .85rem;font-size:.85rem;transition:all .15s}.target-chip.active{background:var(--green-pale);border-color:var(--green);color:var(--green);font-weight:600}.added-by-icon{font-size:.85rem}.badge-added-by{color:#1d4ed8;background:#e8f4ff}.route-card.added-by-me{border-left-color:#1d4ed8;border-right-color:#1d4ed8}.added-by-info{color:#1d4ed8;background:#e8f4ff;padding:.5rem 1rem .75rem;font-size:.8rem}.added-by-email{display:none}.permission-picker{background:var(--bg);text-align:left;border-radius:10px;margin:.75rem 0;padding:.75rem}.permission-picker-title{color:var(--text-muted);text-transform:uppercase;letter-spacing:.04em;margin-bottom:.6rem;font-size:.82rem;font-weight:700}.permission-option{border-bottom:1px solid var(--border);cursor:pointer;align-items:flex-start;gap:.6rem;padding:.5rem 0;display:flex}.permission-option:last-of-type{border-bottom:none}.permission-option input[type=checkbox]{flex-shrink:0;width:16px;height:16px;margin-top:3px}.permission-name{font-size:.875rem;font-weight:600;display:block}.permission-desc{color:var(--text-muted);margin-top:2px;font-size:.75rem;line-height:1.4;display:block}.permission-expiry{align-items:center;gap:.5rem;padding-top:.6rem;display:flex}.permission-expiry-label{color:var(--text-muted);white-space:nowrap;font-size:.78rem}.permission-date-input{border:1.5px solid var(--border);border-radius:8px;flex:1;padding:.4rem .6rem;font-size:.85rem}.clear-date{cursor:pointer;color:var(--text-muted);background:0 0;border:none;font-size:.9rem}.modal-backdrop--center{justify-content:center!important;align-items:center!important}.added-notif-sheet{background:var(--card);border-radius:16px;width:calc(100% - 2rem);max-width:360px;box-shadow:0 8px 40px #0003}.added-notif-body{text-align:center;padding:1.5rem}.added-notif-body h3{margin-bottom:.75rem;font-size:1.1rem}.added-notif-line{color:var(--text);margin-bottom:.4rem;font-size:.875rem}.share-item--block{flex-direction:column;align-items:flex-start;gap:.5rem}.share-item--expired{opacity:.65}.share-perms{flex-wrap:wrap;gap:.4rem;margin-top:.25rem;display:flex}.share-perm{background:var(--green-pale);color:var(--green);border-radius:5px;padding:.15rem .45rem;font-size:.72rem}.share-perm--expired{color:#c0392b;background:#fdecea}.share-edit-btn{border:1.5px solid var(--border);color:var(--text-muted);cursor:pointer;background:0 0;border-radius:6px;padding:.25rem .6rem;font-size:.75rem}.share-edit-form{border-top:1px solid var(--border);flex-direction:column;gap:.5rem;width:100%;padding-top:.5rem;display:flex}.share-edit-check{cursor:pointer;align-items:center;gap:.5rem;font-size:.85rem;display:flex}.share-edit-date{color:var(--text-muted);flex-direction:column;gap:.25rem;font-size:.82rem;display:flex}.share-edit-date label{color:var(--text-muted);font-size:.78rem}.share-edit-date-row{align-items:center;gap:.4rem;display:flex}.share-edit-date input{border:1.5px solid var(--border);border-radius:6px;padding:.35rem .5rem;font-size:.82rem}.share-edit-date button{cursor:pointer;color:var(--text-muted);background:0 0;border:none}.share-edit-perm-row{border-bottom:1px solid var(--border);flex-direction:column;gap:.3rem;padding-bottom:.5rem;display:flex}.share-edit-perm-row:last-of-type{border-bottom:none}.share-edit-btns{gap:.5rem;display:flex}.permission-expiry-field{padding:.4rem 0 0 1.4rem}.permission-expiry-field .permission-expiry-label{color:var(--text-muted);margin-bottom:.2rem;font-size:.78rem;display:block}.permission-expiry-row{align-items:center;gap:.4rem;display:flex}.share-my-id-box{background:var(--surface-alt,var(--surface));border:1.5px solid var(--border);border-radius:12px;margin-bottom:1.25rem;padding:.875rem 1rem}.share-my-id-title{color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;margin-bottom:.3rem;font-size:.75rem;font-weight:700}.share-my-id-value{color:var(--text);letter-spacing:.03em;margin-bottom:.35rem;font-family:monospace;font-size:1.05rem;font-weight:700}.share-my-id-info{color:var(--text-muted);margin:0;font-size:.78rem}.share-subsection{margin-bottom:1rem}.share-subsection-title{color:var(--text-muted);text-transform:uppercase;letter-spacing:.04em;margin-bottom:.5rem;font-size:.8rem;font-weight:700}.share-count{font-weight:400}.share-empty{color:var(--text-muted);font-size:.82rem}.share-item{border-bottom:1px solid var(--border);flex-wrap:wrap;justify-content:space-between;align-items:center;gap:.5rem;padding:.5rem 0;display:flex}.share-item-info{flex-direction:column;display:flex}.share-name{font-size:.875rem;font-weight:600}.share-email{color:var(--text-muted);font-size:.75rem}.share-item-actions{flex-wrap:wrap;align-items:center;gap:.5rem;display:flex}.share-revoke{color:#c0392b;cursor:pointer;background:0 0;border:1.5px solid #e07070;border-radius:6px;padding:.25rem .6rem;font-size:.75rem}.btn-request-back{background:var(--green-pale);border:1.5px solid var(--green);color:var(--green);cursor:pointer;border-radius:6px;padding:.25rem .6rem;font-size:.75rem;font-weight:600}.share-status{border-radius:6px;padding:.2rem .5rem;font-size:.72rem}.share-status.pending{color:#856404;background:#fff3cd}.share-status.accepted{background:var(--green-pale);color:var(--green)}.share-request-row{gap:.5rem;display:flex}.share-email-input{border:1.5px solid var(--border);border-radius:10px;flex:1;padding:.6rem .75rem;font-size:.9rem}.btn-send-request{background:var(--green);color:#fff;cursor:pointer;white-space:nowrap;border:none;border-radius:10px;padding:.6rem 1rem;font-size:.875rem;font-weight:600}.btn-send-request:disabled{opacity:.5;cursor:not-allowed}.compare-selector{background:var(--card);border-radius:12px;padding:.65rem .75rem}.compare-label{color:var(--text);text-align:center;margin-bottom:.6rem;font-size:1.05rem;font-weight:800}.compare-friends{flex-wrap:wrap;justify-content:center;gap:.4rem;display:flex}.compare-chip{border:1.5px solid var(--border);background:var(--bg);cursor:pointer;color:var(--text-muted);border-radius:20px;align-items:center;gap:.35rem;padding:.35rem .75rem;font-size:.82rem;transition:all .15s;display:flex}.compare-chip.active{font-weight:600}.compare-chip.disabled{opacity:.4;cursor:not-allowed}.compare-chip-action{opacity:.7;margin-left:.1rem;font-weight:700}.modal-header-actions{align-items:center;gap:.4rem;display:flex}.modal-forward-btn{cursor:pointer;color:var(--green);background:0 0;border:none;padding:.2rem;display:inline-flex}.modal-forward-btn:hover{opacity:.7}.forward-recipients{flex-wrap:wrap;gap:.4rem;display:flex}.detail-actions{flex-direction:column;gap:.5rem;margin-top:1rem;display:flex}.forward-banner{background:#eef4ff;border:1px solid #cfe0ff;border-radius:10px;margin:.5rem .75rem 0;padding:.6rem .75rem}.forward-banner-from{color:#1d4ed8;font-size:.85rem}.forward-banner-msg{color:var(--text);margin-top:.3rem;font-size:.9rem;font-style:italic}.forward-banner-actions{flex-direction:column;gap:.4rem;margin-top:.75rem;display:flex}.btn-mark-read{width:100%}.btn-later{border:1px solid var(--border);width:100%;color:var(--text-muted);cursor:pointer;background:0 0;border-radius:10px;padding:.55rem 1rem;font-size:.95rem}.btn-later:hover{background:var(--surface-hover,#f3f4f6)}.burger-badge{color:#fff;background:#e0192b;border-radius:8px;justify-content:center;align-items:center;min-width:16px;height:16px;padding:0 4px;font-size:.65rem;font-weight:700;display:inline-flex;position:absolute;top:-4px;right:-4px}.header-burger{position:relative}.burger-item-badge{color:#fff;background:#e0192b;border-radius:9px;justify-content:center;align-items:center;min-width:18px;height:18px;margin-left:auto;padding:0 5px;font-size:.7rem;font-weight:700;display:inline-flex}.inbox-list{flex-direction:column;gap:.5rem;display:flex}.inbox-item{border:1.5px solid var(--border);border-radius:12px;align-items:stretch;gap:.4rem;display:flex;overflow:hidden}.inbox-item--unread{background:#f5f8ff;border-color:#1d4ed8}.inbox-item-main{text-align:left;cursor:pointer;min-width:0;color:var(--text);background:0 0;border:none;flex:1;padding:.6rem .75rem}.inbox-item-head{align-items:center;gap:.4rem;display:flex}.inbox-unread-dot{background:#1d4ed8;border-radius:50%;flex-shrink:0;width:8px;height:8px}.inbox-from{font-size:.9rem;font-weight:700}.inbox-date{color:var(--text-muted);margin-left:auto;font-size:.75rem}.inbox-item-sub{align-items:center;gap:.5rem;margin-top:.25rem;display:flex}.inbox-grade{font-size:.9rem;font-weight:800}.inbox-msg{color:var(--text-muted);text-overflow:ellipsis;white-space:nowrap;font-size:.8rem;font-style:italic;overflow:hidden}.inbox-del-btn{cursor:pointer;background:0 0;border:none;padding:0 .6rem;font-size:1rem}.inbox-del-confirm{flex-direction:column;justify-content:center;gap:.3rem;padding:.3rem .5rem;display:flex}.compare-dot{border-radius:50%;flex-shrink:0;width:9px;height:9px;display:inline-block}.compare-legend{color:var(--text-muted);flex-wrap:wrap;justify-content:center;align-items:center;gap:.75rem;margin-top:.6rem;font-size:.78rem;display:flex}.compare-legend span{align-items:center;gap:.3rem;display:flex}.bar-tooltip-wrap{cursor:pointer;width:100%;position:relative}.bar-tooltip{color:#fff;white-space:nowrap;z-index:20;pointer-events:none;background:#000000c7;border-radius:6px;padding:.3rem .6rem;font-size:.75rem;position:absolute;bottom:calc(100% + 4px);left:0}.month-row-group{align-items:flex-start;gap:.5rem;margin-bottom:.1rem;display:flex}.month-bars-stack{flex-direction:column;flex:1;gap:3px;display:flex}.month-bar-row{align-items:center;gap:.5rem;display:flex}.month-bar-friend{border-radius:6px;align-items:center;min-width:22px;height:22px;padding-left:6px;display:flex}.month-bar-friend span{color:#fff;white-space:nowrap;font-size:.7rem;font-weight:700}.pending-sheet{background:var(--card);border-radius:16px;width:calc(100% - 2rem);max-width:400px;box-shadow:0 8px 40px #0003}.pending-body{text-align:center;padding:1.5rem}.pending-icon{margin-bottom:.5rem;font-size:2.5rem}.pending-body h3{margin-bottom:.75rem;font-size:1.1rem}.pending-body p{color:var(--text);margin-bottom:.5rem;font-size:.875rem;line-height:1.5}.pending-hint{color:var(--text-muted);margin-bottom:1rem;font-size:.78rem}.pending-btns{justify-content:center;gap:.75rem;margin-top:1rem;display:flex}.btn-accept{background:var(--green);color:#fff;cursor:pointer;border:none;border-radius:10px;flex:1;padding:.7rem;font-size:.95rem;font-weight:600}.btn-decline{color:var(--text-muted);border:1.5px solid var(--border);cursor:pointer;background:0 0;border-radius:10px;flex:1;padding:.7rem;font-size:.95rem}.pending-count{color:var(--text-muted);margin-top:.75rem;font-size:.75rem}.grade-filter-panel{background:var(--card);border:1.5px solid var(--border);border-radius:12px;overflow:hidden}.grade-filter-toggle{cursor:pointer;width:100%;color:var(--text);text-align:left;background:0 0;border:none;align-items:center;gap:.5rem;padding:.5rem .75rem;font-size:.875rem;font-weight:600;display:flex}.filter-badge{color:#856404;background:#fff3cd;border-radius:10px;padding:.15rem .5rem;font-size:.72rem;font-weight:700}.filter-chevron{color:var(--text-muted);margin-left:auto;font-size:.7rem}.grade-filter-body{border-top:1px solid var(--border);padding:0 .75rem .75rem}.grade-filter-hint{color:var(--text-muted);margin:.6rem 0 .75rem;font-size:.78rem}.grade-chips{flex-wrap:wrap;gap:.4rem;display:flex}.grade-chip{cursor:pointer;border:1.5px solid;border-radius:8px;padding:.3rem .6rem;font-size:.78rem;font-weight:600;transition:all .12s}.grade-chip.visible{background:var(--green-pale);border-color:var(--green);color:var(--green)}.grade-chip.hidden{color:#aaa;background:#f0f0f0;border-color:#ccc;text-decoration:line-through}.filter-reset-btn{color:#c0392b;cursor:pointer;background:0 0;border:1.5px solid #e07070;border-radius:8px;margin-top:.75rem;padding:.4rem .9rem;font-size:.8rem;font-weight:600}.filter-reset-btn:hover{background:#fdecea}.stats-subtabs{z-index:50;background:var(--card);border-bottom:1.5px solid var(--border);gap:.4rem;margin:-1rem -1rem .75rem;padding:.5rem;display:flex;position:sticky;top:0;box-shadow:0 2px 6px #0000000d}.stats-subtab{text-align:center;color:var(--text-muted);cursor:pointer;border:1.5px solid var(--border);background:var(--bg);border-radius:10px;flex:1;padding:.7rem .3rem;font-size:.92rem;font-weight:700;transition:color .18s,background .18s,border-color .18s,box-shadow .18s}.stats-subtab:hover{color:var(--green);border-color:var(--green-light)}.stats-subtab.active{color:#fff;background:var(--green);border-color:var(--green);box-shadow:0 3px 10px #2d6a4f59}.stats-period-heading{text-align:center;color:var(--green);background:var(--green-pale);border-radius:10px;margin:1.1rem 0 .85rem;padding:.55rem .75rem;font-size:1.15rem;font-weight:800;display:block}.period-selector{flex-wrap:wrap;gap:.4rem;display:flex}.period-btn{border:1.5px solid var(--border);background:var(--bg);cursor:pointer;color:var(--text-muted);border-radius:20px;padding:.35rem .85rem;font-size:.82rem;font-weight:500;transition:all .15s}.period-btn.active{background:var(--green);border-color:var(--green);color:#fff;font-weight:600}.btn-delete{color:#c0392b;cursor:pointer;background:0 0;border:1.5px solid #e07070;border-radius:12px;width:100%;margin-top:.5rem;padding:.7rem;font-size:.9rem;transition:all .15s}.btn-delete:hover{background:#fdecea}.delete-confirm{text-align:center;background:#fdecea;border-radius:10px;margin-top:.5rem;padding:.75rem}.delete-confirm p{color:#c0392b;margin-bottom:.5rem;font-size:.875rem;font-weight:600}.delete-confirm-btns{gap:.5rem;display:flex}.btn-delete-confirm{color:#fff;cursor:pointer;background:#c0392b;border:none;border-radius:8px;flex:1;padding:.55rem;font-size:.875rem;font-weight:600}.btn-cancel{color:var(--text-muted);border:1.5px solid var(--border);cursor:pointer;background:#fff;border-radius:8px;flex:1;padding:.55rem;font-size:.875rem}.modal-backdrop.onboarding-backdrop{justify-content:center!important;align-items:center!important}.onboarding-sheet{background:var(--card);border-radius:16px;flex-direction:column;width:calc(100% - 2rem);max-width:440px;max-height:90dvh;display:flex;box-shadow:0 8px 40px #0003}.onboarding-header{padding:1.5rem 1.5rem .75rem}.onboarding-header h2{color:var(--green);margin-bottom:.5rem;font-size:1.2rem}.onboarding-header p{color:var(--text-muted);font-size:.85rem;line-height:1.5}.onboarding-body{flex:1;padding:0 1.5rem;overflow-y:auto}.onboarding-type-block{border-bottom:1px solid var(--border);padding:.75rem 0}.onboarding-type-block:last-child{border-bottom:none}.onboarding-type-label{color:var(--green);text-transform:uppercase;letter-spacing:.05em;margin-bottom:.5rem;font-size:.82rem;font-weight:700}.onboarding-row{gap:.75rem;display:flex}.onboarding-field{flex-direction:column;flex:1;gap:.25rem;display:flex}.onboarding-field label{color:var(--text-muted);font-size:.75rem;font-weight:500}.grant-card{border:1.5px solid var(--border);background:var(--card);border-radius:12px;margin-bottom:.7rem;padding:.7rem .8rem}.grant-card--expired{opacity:.6}.grant-card-head{justify-content:space-between;align-items:flex-start;gap:.5rem;display:flex}.grant-identity{flex-direction:column;min-width:0;display:flex}.grant-name{color:var(--text);font-size:.98rem;font-weight:700}.grant-email{color:var(--text-muted);text-overflow:ellipsis;font-size:.78rem;overflow:hidden}.grant-revoke{color:#c0392b;cursor:pointer;background:#fdecea;border:none;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:26px;height:26px;font-size:.8rem;display:inline-flex}.grant-revoke:hover{background:#f8d7d3}.grant-status-row{flex-wrap:wrap;align-items:center;gap:.5rem;min-height:1.2rem;margin-top:.35rem;display:flex}.grant-saved{color:var(--green);font-size:.75rem;font-weight:600}.grant-perms{flex-direction:column;gap:.1rem;margin-top:.6rem;display:flex}.perm-row{border-top:1px solid var(--border);padding:.4rem 0}.perm-row:first-child{border-top:none}.perm-row-head{align-items:center;gap:.55rem;display:flex}.perm-row-label{color:var(--text);flex:1;font-size:.88rem}.perm-row-expiry{align-items:center;gap:.4rem;margin-top:.45rem;padding-left:2.85rem;display:flex}.perm-row-expiry-label{color:var(--text-muted);flex-shrink:0;font-size:.78rem;font-weight:600}.perm-row-expiry input{border:1.5px solid var(--border);background:var(--card);color:var(--text);border-radius:8px;padding:.35rem .5rem;font-size:.82rem}.grant-remove-confirm{color:#c0392b;background:#fdecea;border:1px solid #f5c6cb;border-radius:10px;flex-direction:column;gap:.5rem;margin-top:.6rem;padding:.6rem .7rem;font-size:.85rem;display:flex}.grant-remove-btns{gap:.5rem;display:flex}.access-item{border:1.5px solid var(--border);background:var(--card);border-radius:12px;margin-bottom:.6rem;padding:.6rem .8rem}.access-item-row{justify-content:space-between;align-items:center;gap:.5rem;display:flex}.perf-compare-row{flex-wrap:wrap;align-items:center;gap:.5rem;margin-top:.5rem;display:flex}.perf-compare-label{color:var(--text-muted);font-size:.78rem;font-weight:600}.perf-compare-chips{flex-wrap:wrap;gap:.4rem;display:flex}.perf-person-chip{border:1.5px solid var(--border);background:var(--bg);color:var(--text-muted);cursor:pointer;border-radius:20px;align-items:center;gap:.35rem;padding:.25rem .65rem;font-size:.8rem;font-weight:500;transition:all .15s;display:inline-flex}.perf-person-chip.active{background:var(--card);font-weight:600}.perf-person-dot{border-radius:50%;flex-shrink:0;width:10px;height:10px}.recharts-wrapper,.recharts-surface,.recharts-wrapper :focus,.recharts-wrapper:focus,.recharts-wrapper:focus-visible,.recharts-surface:focus,.recharts-surface:focus-visible{-webkit-tap-highlight-color:transparent;outline:none!important}.perm-switch{flex-shrink:0;width:38px;height:22px;display:inline-block;position:relative}.perm-switch input{opacity:0;width:0;height:0}.perm-switch-slider{cursor:pointer;background:#cfd4d8;border-radius:22px;transition:all .2s;position:absolute;inset:0}.perm-switch-slider:before{content:"";background:#fff;border-radius:50%;width:16px;height:16px;transition:all .2s;position:absolute;top:3px;left:3px}.perm-switch input:checked+.perm-switch-slider{background:var(--green)}.perm-switch input:checked+.perm-switch-slider:before{transform:translate(16px)}.info-icon-wrap{flex-shrink:0;display:inline-flex;position:relative}.info-icon{cursor:pointer;color:var(--text-muted);background:0 0;border:none;padding:2px;font-size:1rem;line-height:1}.info-icon:hover{color:var(--green)}.info-popover{z-index:20;background:var(--text);color:#fff;border-radius:8px;width:230px;padding:.6rem .7rem;font-size:.78rem;line-height:1.4;position:absolute;top:130%;right:0;box-shadow:0 4px 16px #00000040}.person-switcher{flex-wrap:wrap;gap:.4rem;padding:.6rem 1rem .2rem;display:flex}.person-chip{border:1.5px solid var(--border);background:var(--bg);color:var(--text-muted);cursor:pointer;border-radius:20px;padding:.3rem .75rem;font-size:.82rem;font-weight:500;transition:all .15s}.person-chip.active{background:var(--green);color:#fff;border-color:var(--green)}.readonly-banner{color:#1d4ed8;background:#eef4ff;border:1px solid #cfe0ff;border-radius:10px;flex-direction:column;gap:.15rem;margin:.4rem 1rem .9rem;padding:.5rem .7rem;font-size:.85rem;font-weight:600;display:flex}.readonly-banner-hint{color:#3b6fd4;font-size:.75rem;font-weight:400}.modal-sheet.route-detail-sheet{border-radius:16px;width:calc(100% - 2rem);max-width:420px;margin:0 auto;overflow:hidden}.modal-sheet.route-edit-sheet{border-radius:16px;width:calc(100% - 2rem);max-width:480px;margin:0 auto;overflow:hidden}.route-detail-grade{align-items:center;gap:.6rem;margin-bottom:.8rem;display:flex}.detail-color-dot{border-radius:50%;flex-shrink:0;width:20px;height:20px}.route-detail-list{flex-direction:column;display:flex}.detail-row{border-bottom:1px solid var(--border);justify-content:space-between;gap:1rem;padding:.55rem 0;display:flex}.detail-row:last-child{border-bottom:none}.detail-label{color:var(--text-muted);flex-shrink:0;font-size:.82rem;font-weight:600}.detail-value{color:var(--text);text-align:right;font-size:.9rem}.onboarding-select{border:1.5px solid var(--border);background:#fff;border-radius:8px;padding:.5rem .6rem;font-size:.85rem}.onboarding-footer{flex-direction:column;gap:.5rem;padding:1rem 1.5rem 1.5rem;display:flex}.btn-skip{color:var(--text-muted);cursor:pointer;text-align:center;background:0 0;border:none;padding:.3rem;font-size:.875rem;text-decoration:underline}.btn-back{border:1.5px solid var(--border);color:var(--text-muted);cursor:pointer;background:0 0;border-radius:8px;padding:.5rem 1rem;font-size:.875rem}.onboarding-steps{gap:6px;margin-top:.75rem;display:flex}.onboarding-step-dot{background:var(--border);border-radius:50%;width:8px;height:8px;transition:background .2s}.onboarding-step-dot.active{background:var(--green)}.onboarding-step-dot.done{background:var(--green-light,#a7c4b5)}.onboarding-step-title{color:var(--text);margin-bottom:.5rem;font-size:.95rem;font-weight:700}.onboarding-step-hint{color:var(--text-muted);margin-bottom:1rem;font-size:.82rem}.onboarding-system-picker{flex-direction:column;gap:.6rem;margin:.5rem 0;display:flex}.onboarding-system-btn{border:2px solid var(--border);background:var(--card);cursor:pointer;text-align:left;border-radius:12px;flex-direction:column;align-items:flex-start;padding:.75rem 1rem;transition:border-color .15s,background .15s;display:flex}.onboarding-system-btn.active{border-color:var(--green);background:#2d6a4f0f}.system-short{color:var(--green);font-size:1rem;font-weight:800}.system-label{color:var(--text-muted);margin-top:1px;font-size:.8rem}.system-example{color:var(--text-muted);margin-top:3px;font-size:.75rem;font-style:italic}.modal-backdrop{z-index:100;background:#00000073;justify-content:center;align-items:flex-end;width:100vw;height:100dvh;display:flex;position:fixed;inset:0}.modal-sheet{background:var(--card);border-radius:20px 20px 0 0;flex-direction:column;width:100%;max-width:480px;max-height:92dvh;margin:0 auto;display:flex}.modal-handle{background:#ddd;border-radius:2px;flex-shrink:0;width:40px;height:4px;margin:10px auto 0}.modal-header{flex-shrink:0;justify-content:space-between;align-items:center;padding:.75rem 1rem .5rem;display:flex}.modal-header h3{font-size:1rem;font-weight:700}.modal-close{cursor:pointer;color:var(--text-muted);background:0 0;border:none;padding:.25rem;font-size:1.1rem}.modal-body{-webkit-overflow-scrolling:touch;padding:0 1rem 2rem;overflow-y:auto}.route-tag-picker{flex-direction:column;gap:.6rem;display:flex}.opt-field-label-text{align-items:center;gap:.3rem;display:inline-flex}.opt-field-label-extra{align-items:center;display:inline-flex}.tag-info-btn{cursor:pointer;opacity:.5;background:0 0;border:none;align-items:center;padding:0;font-size:.9rem;line-height:1;display:inline-flex}.tag-info-btn:hover{opacity:1}.tag-info-backdrop{z-index:300;background:#00000073;justify-content:center;align-items:center;padding:1rem;display:flex;position:fixed;inset:0}.tag-info-dialog{background:var(--card);text-transform:none;letter-spacing:normal;border-radius:16px;flex-direction:column;gap:.4rem;width:min(340px,92vw);max-height:80dvh;padding:1.1rem 1.1rem 1.2rem;font-weight:400;display:flex;position:relative;overflow-y:auto}.tag-info-close{cursor:pointer;color:var(--text-muted);background:0 0;border:none;padding:.1rem .3rem;font-size:1rem;position:absolute;top:.7rem;right:.8rem}.tag-info-section-label{color:var(--text-muted);margin-top:.2rem;font-size:.85rem;font-weight:700}.tag-info-row{flex-direction:column;gap:.05rem;display:flex}.tag-info-name{color:var(--text);font-size:.82rem;font-weight:600}.tag-info-desc{color:var(--text-muted);padding-left:0;font-size:.75rem}.tag-info-divider{background:var(--border);height:1px;margin:.3rem 0}.tag-group{flex-direction:column;gap:.3rem;display:flex}.tag-group-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.04em;font-size:.72rem;font-weight:600}.tag-chip-row{flex-wrap:wrap;gap:.4rem;display:flex}.tag-chip-divider{background:var(--border);width:100%;height:1px;margin:.05rem 0}.tag-chip{border:1.5px solid var(--border);background:var(--card);color:var(--text-muted);cursor:pointer;white-space:nowrap;border-radius:20px;padding:.45rem .75rem;font-size:.9rem;transition:all .15s}.tag-chip.active{background:var(--green-pale);border-color:var(--green);color:var(--green);font-weight:600}.tag-chip--readonly{cursor:default;pointer-events:none}.detail-row--tags{align-items:flex-start!important}.detail-tags{flex-wrap:wrap;gap:.35rem;display:flex}.optional-section{flex-direction:column;gap:0;display:flex}.optional-toggle{border:none;border-top:1.5px dashed var(--border);color:var(--text-muted);text-transform:uppercase;letter-spacing:.06em;cursor:pointer;text-align:left;background:0 0;align-items:center;gap:.4rem;width:100%;padding:.65rem 0 .55rem;font-size:.78rem;font-weight:700;transition:color .15s;display:flex}.optional-toggle:hover{color:var(--green)}.optional-toggle-arrow{font-size:.85rem;line-height:1;transition:transform .15s}.optional-fields{flex-direction:column;gap:.85rem;padding-top:.6rem;display:flex}.optional-toggle{justify-content:space-between;align-items:center}.optional-toggle-label{letter-spacing:.08em;text-transform:uppercase;color:inherit;font-size:.78rem;font-weight:700}.optional-toggle-arrow{background:var(--green-pale);width:1.75rem;height:1.75rem;color:var(--green);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-size:1.15rem;font-weight:700;line-height:1;transition:background .15s,transform .15s;display:flex}.optional-toggle:hover .optional-toggle-arrow{background:var(--green);color:#fff;transform:scale(1.08)}.badge-repeat{color:#1565c0;background:#e8f4fd;border:1px solid #90caf9}.badge-linked{color:#6a1b9a;background:#f3e5f5;border:1px solid #ce93d8;padding:.1rem .35rem;font-size:.85rem}.tag-chip--linked{align-items:center;gap:.3rem;font-size:.82rem;font-weight:600;display:inline-flex}.linked-route-date{color:var(--text-muted);font-size:.72rem;font-weight:400}.btn-readd{border:1.5px dashed var(--green);width:100%;color:var(--green);cursor:pointer;background:0 0;border-radius:12px;margin-top:.5rem;padding:.7rem;font-size:.95rem;font-weight:600;transition:background .15s}.btn-readd:hover{background:var(--green-pale)}.btn-forward{justify-content:center;align-items:center;gap:.4rem;display:flex}.btn-forward svg{display:block}.linked-hint{color:#6a1b9a;background:#f3e5f5;border:1px solid #ce93d8;border-radius:8px;padding:.4rem .7rem;font-size:.8rem}.settings-hint--warn{color:#6d5200;background:#fff8e1;border:1px solid #ffe082;border-radius:8px;padding:.55rem .7rem}.hide-types-list{flex-direction:column;gap:.4rem;margin-bottom:.75rem;display:flex}.hide-types-list .completed-row{border-bottom:1px solid var(--border);padding-bottom:.4rem}.hide-types-list .completed-row:last-child{border-bottom:none}.opt-field-label{align-items:center;gap:.4rem;display:inline-flex!important}.fav-star{cursor:pointer;color:#ccc;opacity:1;background:0 0;border:none;padding:0;font-size:1.35rem;line-height:1;transition:color .15s,transform .1s}.fav-star:hover{color:#e0334c;transform:scale(1.2)}.fav-star.active{color:#e0334c;opacity:1}.optional-favorites{flex-direction:column;gap:.85rem;display:flex}.add-card{background:var(--card);border-radius:20px;margin-bottom:12px;padding:18px;box-shadow:0 2px 10px #0000000f}.add-card--accent{border-left:3px solid var(--green)}.add-card-label{letter-spacing:1.1px;color:var(--text-muted);text-transform:uppercase;margin-bottom:12px;font-size:13px;font-weight:700}.add-card-label--green{color:var(--green)}.add-card-divider{border:none;border-top:1px solid var(--border);margin:14px 0}.add-card-field-stack{flex-direction:column;gap:14px;display:flex}.add-form--cards{gap:0}.person-chips{flex-wrap:wrap;gap:8px;display:flex}.person-chip-new{border:2px solid var(--border);background:var(--bg);cursor:pointer;border-radius:50px;align-items:center;gap:7px;padding:5px 13px 5px 5px;transition:all .15s;display:flex}.person-chip-new.active{border-color:var(--green);background:var(--green-pale)}.person-chip-avatar{color:#fff;background:#ccc;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:28px;height:28px;font-size:12px;font-weight:700;display:flex}.person-chip-new.active .person-chip-avatar{background:var(--green)}.person-chip-name{color:var(--text-muted);font-size:14px;font-weight:600}.person-chip-new.active .person-chip-name{color:var(--green)}.add-datetime-row{gap:10px;margin-top:12px;display:flex}.add-datetime-pill{background:var(--bg);cursor:pointer;border-radius:12px;flex:1;align-items:center;gap:8px;padding:11px 14px;display:flex}.add-datetime-pill input[type=date],.add-datetime-pill input[type=time]{color:var(--text);cursor:pointer;background:0 0;border:none;outline:none;width:100%;padding:0;font-family:inherit;font-size:15px;font-weight:600}.add-datetime-pill svg{color:var(--text-muted);flex-shrink:0}.add-type-row{gap:10px;display:flex}.add-type-btn{background:var(--bg);color:var(--text);cursor:pointer;border:none;border-radius:12px;flex:1;justify-content:space-between;align-items:center;gap:6px;padding:13px 14px;font-family:inherit;font-size:15px;font-weight:600;display:flex}.add-type-btn-inner{color:var(--green);align-items:center;gap:7px;display:flex}.add-type-chevron{color:var(--text-muted);flex-shrink:0}.rope-type-pills{gap:6px;margin-top:10px;display:flex}.rope-type-pill{border:2px solid var(--border);background:var(--bg);color:var(--text-muted);cursor:pointer;text-align:center;border-radius:12px;flex:1;padding:10px 8px;font-size:14px;font-weight:600}.rope-type-pill.active{border-color:var(--green);background:var(--green-pale);color:var(--green)}.grade-stepper{text-align:center}.grade-stepper-header{justify-content:center;align-items:center;gap:10px;margin-bottom:10px;display:flex}.grade-stepper-sublabel{letter-spacing:1.4px;color:var(--text-muted);text-transform:uppercase;font-size:11px;font-weight:700}.grade-unknown-btn{border:1.5px solid var(--border);color:var(--text-muted);cursor:pointer;background:var(--bg);letter-spacing:.3px;border-radius:12px;padding:3px 10px;font-size:11px;font-weight:600;transition:border-color .15s,color .15s,background .15s}.grade-unknown-btn.active{border-color:var(--green);color:var(--green);background:var(--green-pale)}.grade-stepper-value--unknown{color:var(--text-muted)}.grade-stepper-row{justify-content:center;align-items:center;gap:20px;display:flex}.grade-stepper-btn{border:2px solid var(--border);background:var(--card);width:46px;height:46px;color:var(--text-muted);cursor:pointer;border-radius:50%;justify-content:center;align-items:center;font-size:24px;transition:border-color .15s;display:flex}.grade-stepper-btn:active{border-color:var(--green)}.grade-stepper-value{color:var(--text);letter-spacing:-2px;text-align:center;min-width:110px;font-size:54px;font-weight:900;line-height:1}.grade-sys-pills{justify-content:center;gap:6px;margin-top:10px;display:flex}.grade-sys-pill{border:1.5px solid var(--border);color:var(--text-muted);cursor:pointer;background:var(--bg);border-radius:20px;padding:5px 13px;font-size:13px;font-weight:600}.grade-sys-pill.active{border-color:var(--green);color:var(--green);background:var(--green-pale)}.route-toggle-row{justify-content:space-between;align-items:center;gap:12px;display:flex}.route-toggle-label{color:var(--text);font-size:16px;font-weight:600}.route-toggle-sub{color:var(--text-muted);margin-top:3px;font-size:13px}.flash-row{justify-content:flex-end;align-items:center;gap:8px;margin-top:2px;display:flex}.attempts-control{align-items:center;gap:10px;display:flex}.flash-btn{border:2px solid var(--border);color:var(--text-muted);background:var(--bg);cursor:pointer;white-space:nowrap;border-radius:20px;padding:7px 13px;font-size:13px;font-weight:700}.flash-btn.active{color:#c97d00;background:#fff8ec;border-color:#f5a623}.small-stepper{align-items:center;gap:10px;display:flex}.small-stepper-btn{border:2px solid var(--border);background:var(--card);width:38px;height:38px;color:var(--text-muted);cursor:pointer;border-radius:50%;justify-content:center;align-items:center;font-size:20px;display:flex}.small-stepper-btn:active{border-color:var(--green)}.small-stepper-value{color:var(--text);text-align:center;min-width:36px;font-size:26px;font-weight:900;line-height:1}.small-stepper-value--empty{color:var(--text-muted);font-size:20px}.opt-field-label-new{align-items:center;gap:5px;margin-bottom:0;display:flex}.opt-field-label-new .opt-label-text{color:var(--text-muted);font-size:14px;font-weight:600}.optional-section-card{background:var(--card);border-radius:20px;margin-bottom:12px;overflow:hidden;box-shadow:0 2px 10px #0000000f}.optional-toggle-new{cursor:pointer;width:100%;color:var(--text-muted);text-align:left;background:0 0;border:none;justify-content:space-between;align-items:center;padding:16px 18px;font-family:inherit;font-size:16px;font-weight:600;display:flex}.optional-toggle-new:hover{color:var(--green)}.optional-toggle-arrow-new{background:var(--green-pale);width:28px;height:28px;color:var(--green);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-size:1rem;font-weight:700;transition:background .15s;display:flex}.optional-toggle-new:hover .optional-toggle-arrow-new{background:var(--green);color:#fff}.optional-fields-card-inner{border-top:1px solid var(--border);flex-direction:column;gap:14px;padding:4px 18px 18px;display:flex}.optional-favorites-card{flex-direction:column;gap:14px;display:flex}.route-filter-accordion{border:1.5px solid var(--border);background:var(--card);border-radius:12px;margin-bottom:.5rem;margin-left:1rem;margin-right:1rem;overflow:hidden}.filter-toggle--open{border-radius:0}.filter-toggle{cursor:pointer;width:100%;color:var(--text);background:0 0;border:none;justify-content:space-between;align-items:center;padding:.45rem .75rem;display:flex}.filter-toggle-label{align-items:center;gap:.5rem;font-size:.85rem;font-weight:700;display:inline-flex}.filter-count{background:var(--green);color:#fff;border-radius:999px;justify-content:center;align-items:center;min-width:1.25rem;height:1.25rem;padding:0 .35rem;font-size:.72rem;font-weight:700;display:inline-flex}.filter-body{border-top:1.5px solid var(--border);flex-direction:column;gap:.85rem;padding:.85rem .75rem .75rem;display:flex}.sort-row{align-items:center;gap:.5rem;padding:.5rem 1rem;display:flex}.sort-row-label{color:var(--text-muted);font-size:.82rem;font-weight:600}.sort-seg{border:1.5px solid var(--border);background:var(--card);border-radius:20px;display:inline-flex;overflow:hidden}.sort-seg-btn{color:var(--text-muted);cursor:pointer;background:0 0;border:none;padding:.35rem .8rem;font-size:.85rem;font-weight:600}.sort-seg-btn+.sort-seg-btn{border-left:1.5px solid var(--border)}.sort-seg-btn.active{background:var(--green);color:#fff}.filter-row{flex-direction:column;gap:.4rem;display:flex}.filter-row-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.04em;font-size:.75rem;font-weight:700}.filter-subrow{padding-left:.5rem}.active-filter-chips{border-top:1px solid var(--border);flex-wrap:wrap;gap:.4rem;padding:.5rem .75rem .6rem;display:flex}.active-filter-chip{border:1.5px solid var(--green);background:color-mix(in srgb, var(--green) 12%, transparent);color:var(--green);cursor:pointer;white-space:nowrap;border-radius:999px;align-items:center;gap:.3rem;padding:.25rem .6rem;font-size:.78rem;font-weight:600;display:inline-flex}.active-filter-chip:hover{background:color-mix(in srgb, var(--green) 22%, transparent)}.filter-reset{color:var(--green);cursor:pointer;background:0 0;border:none;align-self:flex-start;padding:0;font-size:.8rem;font-weight:600}.pr-sheet{background:var(--card);border-radius:16px;width:calc(100% - 2rem);max-width:420px;max-height:90vh;position:relative;overflow-y:auto;box-shadow:0 8px 40px #0000002e}.pr-close{color:var(--text-muted);cursor:pointer;z-index:1;background:0 0;border:none;padding:.2rem .3rem;font-size:1.1rem;line-height:1;position:absolute;top:.75rem;right:.875rem}.pr-close:hover{color:var(--text)}.pr-body{flex-direction:column;gap:.75rem;padding:0 1.25rem 1.5rem;display:flex}.pr-icon{text-align:center;font-size:2rem}.pr-title{text-align:center;margin:0;font-size:1.05rem;font-weight:700}.pr-subtitle{color:var(--text-muted);text-align:center;margin:0;font-size:.875rem}.pr-section-label{color:var(--text-muted);margin-top:.25rem;font-size:.8rem;font-weight:700}.pr-perms{border:1px solid var(--border);border-radius:10px;flex-direction:column;display:flex;overflow:hidden}.pr-perm-block{border-bottom:1px solid var(--border);padding:.7rem .875rem}.pr-perm-block:last-child{border-bottom:none}.pr-perm-row{cursor:pointer;justify-content:space-between;align-items:flex-start;gap:.75rem;display:flex}.pr-perm-text{flex-direction:column;flex:1;gap:.15rem;display:flex}.pr-perm-name{color:var(--text);font-size:.875rem;font-weight:600}.pr-perm-desc{color:var(--text-muted);font-size:.75rem;line-height:1.4}.pr-expiry-row{flex-wrap:wrap;align-items:center;gap:.5rem;margin-top:.55rem;display:flex}.pr-expiry-label{color:var(--text-muted);white-space:nowrap;font-size:.72rem}.pr-expiry-inputs{align-items:center;gap:.3rem;display:flex}.pr-hint{color:var(--text-muted);text-align:center;margin:0;font-size:.75rem}.pr-btns{flex-direction:column;gap:.5rem;display:flex}.pr-count{color:var(--text-muted);text-align:center;margin:0;font-size:.75rem}.friends-page{flex-direction:column;gap:1.25rem;padding:1rem;display:flex;overflow-y:auto}.my-id-box{background:var(--card);border:1px solid var(--border);border-radius:12px;padding:.875rem 1rem}.my-id-box-header{align-items:center;gap:.4rem;margin-bottom:.4rem;display:flex}.my-id-box-label{text-transform:uppercase;letter-spacing:.06em;color:var(--text-muted);font-size:.7rem;font-weight:700}.my-id-box-row{align-items:center;gap:.75rem;display:flex}.my-id-box-value{color:var(--text);letter-spacing:.03em;flex:1;font-family:monospace;font-size:1rem;font-weight:700}.my-id-copy-btn{background:var(--bg);border:1px solid var(--border);color:var(--text-muted);cursor:pointer;white-space:nowrap;border-radius:7px;padding:.3rem .7rem;font-size:.75rem;font-weight:600}.my-id-copy-btn:hover{color:var(--green);border-color:var(--green)}.friends-section{flex-direction:column;display:flex}.friends-list{flex-direction:column;gap:.5rem;display:flex}.friends-section-header{justify-content:space-between;align-items:center;margin-bottom:.5rem;display:flex}.friends-section-label{text-transform:uppercase;letter-spacing:.07em;color:var(--text-muted);font-size:.7rem;font-weight:700}.btn-add-friend{background:var(--green);color:#fff;cursor:pointer;border:none;border-radius:7px;padding:.35rem .75rem;font-size:.75rem;font-weight:600}.friends-incoming-list{flex-direction:column;gap:.5rem;display:flex}.friends-incoming-row{background:#eaf1fb;border:1px solid #b3d0f5;border-radius:10px;flex-direction:column;gap:.6rem;padding:.75rem 1rem;display:flex}.friends-incoming-info{min-width:0}.friends-incoming-name{color:var(--text);font-size:.9rem;font-weight:600;display:block}.friends-incoming-email{color:var(--text-muted);font-size:.72rem}.friends-incoming-btns{gap:.4rem;display:flex}.btn-friend-accept{background:var(--green);color:#fff;cursor:pointer;border:none;border-radius:6px;padding:.35rem .65rem;font-size:.75rem;font-weight:600}.btn-friend-decline{background:var(--card);color:var(--text-muted);border:1px solid var(--border);cursor:pointer;border-radius:6px;padding:.35rem .65rem;font-size:.75rem}.friend-card{background:var(--card);border:1px solid var(--border);border-radius:12px;overflow:hidden}.friend-card--open{box-shadow:0 2px 10px #00000012}.friend-summary{cursor:pointer;text-align:left;background:0 0;border:none;align-items:center;gap:.75rem;width:100%;padding:.8rem 1rem;display:flex}.friend-avatar{color:#2c6fbd;background:#eaf1fb;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:38px;height:38px;font-size:.85rem;font-weight:700;display:flex}.friend-main{flex-direction:column;flex:1;gap:.1rem;min-width:0;display:flex}.friend-nick{color:var(--text);font-size:.95rem;font-weight:600}.friend-since{color:var(--text-muted);font-size:.7rem}.friend-grant-pill{white-space:nowrap;border-radius:20px;flex-shrink:0;padding:.2rem .5rem;font-size:.68rem;font-weight:600}.friend-grant-pill--yes{color:#2e9e5b;background:#eaf7ef;border:1px solid #b6e8cc}.friend-grant-pill--no{background:var(--bg);color:var(--text-muted);border:1px solid var(--border)}.friend-chevron{width:18px;height:18px;color:var(--text-muted);flex-shrink:0;transition:transform .2s}.friend-card--open .friend-chevron{transform:rotate(180deg)}.friend-body{border-top:1px solid var(--border);background:#f9fafb}.friend-perm-block{border-bottom:1px solid var(--border);padding:.875rem 1rem}.friend-perm-block:last-of-type{border-bottom:none}.friend-perm-block-title{text-transform:uppercase;letter-spacing:.06em;margin-bottom:.6rem;font-size:.68rem;font-weight:700}.friend-perm-block-title--give{color:#2e9e5b}.friend-perm-block-title--get{color:#2c6fbd}.friend-perm-item{cursor:pointer;border-bottom:1px solid #f0f1f4;justify-content:space-between;align-items:center;padding:.45rem 0;display:flex}.friend-perm-item--readonly{cursor:default}.friend-perm-item:last-child,.friend-perm-item--no-border{border-bottom:none}.friend-perm-item-name{color:var(--text);font-size:.875rem}.friend-perm-readonly-val{color:var(--text-muted);font-size:.8rem;font-weight:600}.friend-perm-readonly-val--yes{color:#2e9e5b}.friend-saved-flash{color:var(--green);margin-top:.4rem;font-size:.72rem;display:block}.friend-unlink-row{border-top:1px solid var(--border);justify-content:flex-end;align-items:center;gap:.5rem;padding:.75rem 1rem;display:flex}.btn-unlink{color:#c0392b;cursor:pointer;background:0 0;border:1px solid #f5c6c0;border-radius:7px;padding:.35rem .85rem;font-size:.78rem;font-weight:600}.friend-unlink-confirm{flex-wrap:wrap;align-items:center;gap:.5rem;display:flex}.friend-unlink-confirm-text{color:var(--text);font-size:.82rem}.btn-unlink-yes{color:#fff;cursor:pointer;background:#c0392b;border:none;border-radius:6px;padding:.3rem .65rem;font-size:.78rem;font-weight:600}.btn-unlink-cancel{background:var(--bg);color:var(--text-muted);border:1px solid var(--border);cursor:pointer;border-radius:6px;padding:.3rem .65rem;font-size:.78rem}.friends-empty{color:var(--text-muted);flex-direction:column;align-items:center;gap:.5rem;padding:2rem 1rem;display:flex}.friends-empty-icon{font-size:2.5rem}.friends-sent-list{flex-direction:column;gap:.5rem;display:flex}.friends-sent-row{background:#fef3e6;border:1px solid #f5d8b0;border-radius:10px;align-items:center;gap:.75rem;padding:.7rem 1rem;display:flex}.friends-sent-info{flex:1;min-width:0}.friends-sent-name{color:var(--text);text-overflow:ellipsis;white-space:nowrap;font-size:.875rem;font-weight:600;display:block;overflow:hidden}.friends-sent-sub{color:#c96b1a;font-size:.72rem}.btn-withdraw{color:#c96b1a;cursor:pointer;white-space:nowrap;background:0 0;border:1px solid #f5d8b0;border-radius:7px;padding:.3rem .6rem;font-size:.72rem}.friends-accept-sheet{background:var(--card);border-radius:16px;width:calc(100% - 2rem);max-width:400px;padding-bottom:1rem;box-shadow:0 8px 40px #0000002e}.friends-accept-body{flex-direction:column;gap:.75rem;padding:0 1.25rem 1.25rem;display:flex}.friends-accept-icon{text-align:center;font-size:2rem}.friends-accept-title{text-align:center;font-size:1rem;font-weight:700}.friends-accept-hint{color:var(--text-muted);text-align:center;font-size:.85rem}.friends-perm-list{flex-direction:column;gap:0;display:flex}.friends-perm-toggle-row{border-bottom:1px solid var(--border);cursor:pointer;justify-content:space-between;align-items:center;padding:.55rem 0;display:flex}.friends-perm-toggle-row:last-child{border-bottom:none}.friends-perm-name{color:var(--text);font-size:.875rem}.friends-accept-btns{flex-direction:column;gap:.5rem;margin-top:.25rem;display:flex}.btn-accept-save{background:var(--green);color:#fff;cursor:pointer;border:none;border-radius:10px;padding:.75rem;font-size:.9rem;font-weight:700}.btn-accept-without{background:var(--bg);color:var(--text);border:1px solid var(--border);cursor:pointer;border-radius:10px;padding:.7rem;font-size:.875rem}.btn-decline-friend{color:#c0392b;cursor:pointer;background:0 0;border:none;align-self:center;padding:.25rem;font-size:.82rem}.friends-add-sheet{background:var(--card);border-radius:16px;width:calc(100% - 2rem);max-width:400px;padding:1.25rem 1.25rem 2rem;box-shadow:0 8px 40px #0000002e}.friends-add-title{margin-bottom:1rem;font-size:1rem;font-weight:700}.friends-add-label{color:var(--text-muted);margin-bottom:.35rem;font-size:.8rem;font-weight:700;display:block}.friends-add-perms .pr-perm-block{padding-left:.75rem;padding-right:.75rem}.friends-add-input{background:var(--bg);border:1px solid var(--border);width:100%;color:var(--text);border-radius:9px;outline:none;margin-bottom:.5rem;padding:.65rem .875rem;font-size:.9rem}.friends-add-input:focus{border-color:var(--green)}.friends-add-or{text-align:center;color:var(--text-muted);margin:.25rem 0 .75rem;font-size:.75rem}.friends-add-hint{color:var(--text-muted);margin-bottom:1rem;font-size:.72rem;line-height:1.5}.friends-add-sheet-header{justify-content:space-between;align-items:center;margin-bottom:1rem;display:flex}.friends-add-close{color:var(--text-muted);cursor:pointer;background:0 0;border:none;padding:.2rem .4rem;font-size:1.1rem;line-height:1}.friends-add-close:hover{color:var(--text)}.friend-public-id{border-bottom:1px solid #f0f1f4;align-items:center;gap:.5rem;padding:.4rem 0 .55rem;display:flex}.friend-public-id-label{text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);flex-shrink:0;font-size:.68rem;font-weight:700}.friend-public-id-value{color:var(--text);font-family:monospace;font-size:.82rem;font-weight:600}
