*,:before,:after{box-sizing:border-box;margin:0;padding:0}:root{--bg:#fff;--bg-muted:#f7f8fb;--surface:#fff;--surface-2:#f7f8fb;--surface-hov:#eef1f8;--input-bg:#fbf0f0;--input-bg-hov:#f7e6e6;--border:#e5e7ee;--border-strong:#c8cad6;--border-soft:#eef0f5;--text:#16182e;--text-mute:#3a3f57;--muted:#6b7080;--faint:#a4a8b8;--accent:#3845e3;--accent-h:#2c38c9;--accent-active:#232db0;--accent-bg:#eef0ff;--accent-line:#c7cdff;--hot:#e0466c;--hot-h:#c93656;--hot-bg:#fde9ef;--success:#16a368;--success-bg:#e3f6ec;--danger:#db2c47;--danger-bg:#fceaee;--warning:#c98318;--warning-bg:#fdf1de;--info:#3845e3;--info-bg:#eef0ff;--shadow-xs:0 1px 0 #16182e0a;--shadow:0 1px 3px #16182e0f, 0 1px 2px #16182e0a;--shadow-lg:0 16px 40px -16px #3845e333, 0 2px 8px #16182e0f;--radius:8px;--radius-lg:12px;--radius-pill:999px;--sidebar-w:232px;--serif:"Fraunces", "Iowan Old Style", "Charter", Georgia, serif;--sans:"Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", sans-serif;--mono:"JetBrains Mono", ui-monospace, SFMono-Regular, Menlo, Consolas, monospace}html,body{height:100%}body{font-family:var(--sans);background:var(--bg-muted);color:var(--text);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-feature-settings:"kern", "liga", "calt";font-size:14px;line-height:1.55}a{color:inherit;text-decoration:none}::selection{background:var(--accent);color:#fff}.numeric{font-variant-numeric:tabular-nums lining-nums}.app-layout{min-height:100vh;display:flex}.main-content{margin-left:var(--sidebar-w);background:var(--bg-muted);flex:1;min-height:100vh;padding:2.25rem 2.5rem}.sidebar{width:var(--sidebar-w);background:var(--surface);border-right:1px solid var(--border-soft);z-index:50;flex-direction:column;padding:1.4rem .85rem 1.2rem;display:flex;position:fixed;top:0;bottom:0;left:0}.sidebar-logo{border-bottom:1px solid var(--border-soft);align-items:center;gap:.55rem;margin-bottom:.85rem;padding:.25rem .5rem 1.25rem;display:flex}.logo-icon{background:var(--accent);color:#fff;width:30px;height:30px;font-family:var(--sans);letter-spacing:.02em;border-radius:8px;justify-content:center;align-items:center;font-size:.78rem;font-weight:700;display:inline-flex}.logo-text{font-family:var(--sans);color:var(--text);letter-spacing:-.01em;font-size:1.02rem;font-weight:700}.sidebar-logo-img{object-fit:contain;filter:brightness(0)saturate()invert(8%)sepia(28%)saturate(2235%)hue-rotate(220deg);width:140px;height:auto;max-height:36px;display:block}.sidebar-nav{flex-direction:column;flex:1;gap:1px;padding-top:.25rem;display:flex}.sidebar-section-label{letter-spacing:.13em;text-transform:uppercase;color:var(--faint);padding:.6rem .65rem .35rem;font-size:.65rem;font-weight:700}.sidebar-link{border-radius:var(--radius);color:var(--text-mute);align-items:center;gap:.7rem;padding:.5rem .65rem;font-size:.875rem;font-weight:500;transition:background .12s,color .12s;display:flex;position:relative}.sidebar-link:hover{background:var(--surface-hov);color:var(--text)}.sidebar-link.active{background:var(--accent-bg);color:var(--accent);font-weight:600}.sidebar-link.active:before{content:"";background:var(--accent);border-radius:0 3px 3px 0;width:3px;height:18px;position:absolute;top:50%;left:-.85rem;transform:translateY(-50%)}.sidebar-bottom{border-top:1px solid var(--border-soft);flex-direction:column;gap:.25rem;padding-top:.75rem;display:flex}.sidebar-user{align-items:center;gap:.65rem;padding:.4rem .5rem;display:flex}.user-avatar{background:var(--accent-bg);width:32px;height:32px;color:var(--accent);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-size:.78rem;font-weight:700;display:flex}.user-info{min-width:0;overflow:hidden}.user-name{color:var(--text);white-space:nowrap;text-overflow:ellipsis;font-size:.83rem;font-weight:600;overflow:hidden}.user-email{color:var(--muted);white-space:nowrap;text-overflow:ellipsis;font-size:.72rem;overflow:hidden}.sidebar-logout{cursor:pointer;color:var(--text-mute);border-radius:var(--radius);background:0 0;border:none;align-items:center;gap:.6rem;width:100%;padding:.5rem .65rem;font-family:inherit;font-size:.85rem;font-weight:500;transition:background .12s,color .12s;display:flex}.sidebar-logout:hover{background:var(--danger-bg);color:var(--danger)}.auth-page{background:var(--bg);grid-template-columns:1.05fr 1fr;min-height:100vh;display:grid;position:relative}.auth-page:before{content:"";background:var(--hot);z-index:10;height:3px;position:absolute;top:0;left:0;right:0}.auth-hero{background:linear-gradient(160deg, var(--accent) 0%, var(--accent-active) 100%);color:#fff;flex-direction:column;justify-content:space-between;padding:3.5rem 3rem;display:flex;position:relative;overflow:hidden}.auth-hero:after{content:"";background:#ffffff0f;border-radius:50%;width:420px;height:420px;position:absolute;bottom:-160px;right:-160px}.auth-hero-brand{color:#fff;align-items:center;gap:.6rem;display:flex}.auth-hero-brand-icon{letter-spacing:.04em;background:#ffffff29;border-radius:9px;justify-content:center;align-items:center;width:34px;height:34px;font-size:.85rem;font-weight:700;display:flex}.auth-hero-brand-text{letter-spacing:-.01em;font-size:1.2rem;font-weight:700}.auth-hero-logo{object-fit:contain;width:160px;height:auto;max-height:44px;display:block}.auth-hero-headline{font-family:var(--sans);letter-spacing:-.02em;max-width:420px;margin-top:auto;margin-bottom:1rem;font-size:2.1rem;font-weight:700;line-height:1.18}.auth-hero-sub{color:#ffffffd1;max-width:420px;font-size:.95rem;line-height:1.6}.auth-hero-footer{letter-spacing:.06em;color:#ffffff8c;text-transform:uppercase;margin-top:2.5rem;font-size:.78rem;font-weight:500}.auth-form-wrap{justify-content:center;align-items:center;padding:3rem 2rem;display:flex}.auth-card{background:var(--surface);width:100%;max-width:380px}.auth-header{text-align:center;margin-bottom:1.85rem}.auth-logo{display:none}.auth-title{font-family:var(--sans);color:var(--text);letter-spacing:-.01em;margin-bottom:.35rem;font-size:1.7rem;font-weight:700}.auth-subtitle{color:var(--muted);font-size:.875rem}.auth-form{flex-direction:column;gap:1rem;display:flex}.auth-row-between{justify-content:space-between;align-items:center;margin-top:-.2rem;font-size:.82rem;display:flex}.auth-row-between label{color:var(--muted);cursor:pointer;align-items:center;gap:.4rem;display:inline-flex}.auth-row-between input[type=checkbox]{accent-color:var(--accent)}.auth-footer{text-align:center;color:var(--muted);margin-top:1.5rem;font-size:.85rem}.auth-link{color:var(--accent);font-weight:600;text-decoration:none}.auth-link:hover{text-underline-offset:3px;text-decoration:underline}.auth-link-hot{color:var(--hot)}.auth-link-hot:hover{color:var(--hot-h)}.form-group{flex-direction:column;gap:.35rem;display:flex}.form-label{color:var(--text-mute);align-items:center;gap:.4rem;font-size:.82rem;font-weight:500;display:flex}.input-wrapper{position:relative}.form-input{background:var(--input-bg);border-radius:var(--radius);width:100%;color:var(--text);border:1px solid #0000;outline:none;padding:.6rem .85rem;font-family:inherit;font-size:.9rem;transition:border-color .12s,background .12s,box-shadow .12s}.form-input::placeholder{color:var(--faint)}.form-input:hover{background:var(--input-bg-hov)}.form-input:focus{background:var(--surface);border-color:var(--accent);box-shadow:0 0 0 3px #3845e31f}.form-input.input-error{border-color:var(--danger)}.form-input.input-error:focus{box-shadow:0 0 0 3px #db2c471f}.form-input.input-disabled{background:var(--surface-2);color:var(--muted);cursor:not-allowed}.form-textarea{resize:vertical;min-height:80px;font-family:inherit;line-height:1.55}.password-toggle{cursor:pointer;color:var(--muted);background:0 0;border:none;align-items:center;transition:color .12s;display:flex;position:absolute;top:50%;right:.75rem;transform:translateY(-50%)}.password-toggle:hover{color:var(--text)}.error-msg{color:var(--danger);font-size:.78rem}.field-hint{color:var(--muted);font-size:.75rem}.btn-primary{background:var(--accent);color:#fff;border:1px solid var(--accent);border-radius:var(--radius);cursor:pointer;letter-spacing:.01em;width:100%;padding:.65rem 1.1rem;font-family:inherit;font-size:.9rem;font-weight:600;transition:background .12s,border-color .12s,transform 80ms}.btn-primary:hover:not(:disabled){background:var(--accent-h);border-color:var(--accent-h)}.btn-primary:active:not(:disabled){background:var(--accent-active);transform:translateY(1px)}.btn-primary:disabled{opacity:.55;cursor:not-allowed}.btn-content,.btn-loading{justify-content:center;align-items:center;gap:.5rem;display:flex}.btn-secondary{background:var(--surface);color:var(--text);border:1px solid var(--border);border-radius:var(--radius);cursor:pointer;align-items:center;gap:.45rem;padding:.55rem 1rem;font-family:inherit;font-size:.85rem;font-weight:500;text-decoration:none;transition:background .12s,border-color .12s;display:inline-flex}.btn-secondary:hover{background:var(--surface-2);border-color:var(--border-strong)}.btn-inline{gap:.45rem;width:auto;padding:.55rem 1rem;display:inline-flex}.btn-danger{background:var(--surface);color:var(--danger);border:1px solid var(--border);border-radius:var(--radius);cursor:pointer;align-items:center;gap:.45rem;padding:.55rem 1rem;font-family:inherit;font-size:.85rem;font-weight:500;transition:background .12s,border-color .12s;display:inline-flex}.btn-danger:hover:not(:disabled){background:var(--danger-bg);border-color:var(--danger)}.btn-danger:disabled{opacity:.55;cursor:not-allowed}.spinner,.spinner-sm{border-style:solid;border-color:var(--border-soft);border-top-color:var(--accent);border-radius:50%;animation:.7s linear infinite spin}.spinner{border-width:3px;width:28px;height:28px}.spinner-sm{border-width:2px;width:14px;height:14px;display:inline-block}.loading-screen{background:var(--bg);justify-content:center;align-items:center;min-height:100vh;display:flex}@keyframes spin{to{transform:rotate(360deg)}}.page{max-width:1080px}.page-header{margin-bottom:1.85rem}.page-title{font-family:var(--sans);color:var(--text);letter-spacing:-.02em;font-size:1.7rem;font-weight:700;line-height:1.2}.page-subtitle{color:var(--muted);margin-top:.35rem;font-size:.92rem}.eyebrow{letter-spacing:.14em;text-transform:uppercase;color:var(--accent);margin-bottom:.65rem;font-size:.85rem;font-weight:700}.empty-state{background:var(--surface);border:1px dashed var(--border);border-radius:var(--radius-lg);text-align:center;margin-top:1rem;padding:3rem 2rem}.empty-state-compact{margin-top:0;padding:2rem 1rem}.empty-icon{color:var(--muted);margin-bottom:.65rem;font-size:1.75rem}.empty-title{color:var(--text);margin-bottom:.4rem;font-size:1.05rem;font-weight:600}.empty-text{color:var(--muted);max-width:340px;margin:0 auto;font-size:.875rem}.profile-layout{grid-template-columns:240px 1fr;gap:1.25rem;margin-top:.25rem;display:grid}.profile-avatar-card{background:var(--surface);border:1px solid var(--border-soft);border-radius:var(--radius-lg);text-align:center;height:fit-content;box-shadow:var(--shadow-xs);padding:1.85rem 1.35rem}.profile-avatar{background:var(--accent);color:#fff;border-radius:50%;justify-content:center;align-items:center;width:72px;height:72px;margin:0 auto .85rem;font-size:1.65rem;font-weight:700;display:flex}.profile-name{color:var(--text);font-size:1.05rem;font-weight:700}.profile-email{color:var(--muted);word-break:break-all;margin-top:.2rem;font-size:.82rem}.profile-badge{background:var(--accent-bg);color:var(--accent);border-radius:var(--radius-pill);letter-spacing:.04em;margin-top:1rem;padding:.22rem .65rem;font-size:.7rem;font-weight:600;display:inline-block}.profile-form-card{background:var(--surface);border:1px solid var(--border-soft);border-radius:var(--radius-lg);box-shadow:var(--shadow-xs);padding:1.85rem}.card-title{color:var(--text);letter-spacing:-.01em;margin-bottom:1.25rem;font-size:1.02rem;font-weight:700}.profile-form{flex-direction:column;gap:1.1rem;display:flex}.upload-page,.upload-page-wide{max-width:1100px}.upload-card{background:var(--surface);border:1px solid var(--border-soft);border-radius:var(--radius-lg);box-shadow:var(--shadow-xs);flex-direction:column;gap:1.65rem;padding:1.85rem;display:flex}.tabs{border-bottom:1px solid var(--border-soft);gap:.4rem;margin-bottom:1.5rem;display:flex}.tab{cursor:pointer;font:inherit;color:var(--muted);background:0 0;border:none;border-bottom:2px solid #0000;align-items:center;gap:.5rem;margin-bottom:-1px;padding:.65rem .95rem;font-size:.9rem;font-weight:500;transition:color .12s,border-color .12s;display:inline-flex}.tab:hover{color:var(--text)}.tab.active{color:var(--accent);border-bottom-color:var(--accent);font-weight:600}.dropzone{border:1.5px dashed var(--border-strong);border-radius:var(--radius-lg);text-align:center;cursor:pointer;background:var(--surface-2);padding:2.5rem 1.5rem;transition:border-color .15s,background .15s}.dropzone:hover,.dropzone-active{border-color:var(--accent);background:var(--accent-bg)}.dropzone-disabled{opacity:.55;cursor:not-allowed;pointer-events:none}.dropzone-icon{color:var(--muted);margin-bottom:.55rem}.dropzone-active .dropzone-icon{color:var(--accent)}.dropzone-text{color:var(--text);font-size:.92rem;font-weight:500}.dropzone-hint{color:var(--muted);margin-top:.3rem;font-size:.75rem}.file-selected{background:var(--accent-bg);border:1px solid var(--accent-line);border-radius:var(--radius);justify-content:space-between;align-items:center;padding:.75rem .9rem;display:flex}.file-selected-info{color:var(--text);align-items:center;gap:.7rem;display:flex}.file-selected-info>svg{color:var(--accent)}.file-selected-name{font-size:.88rem;font-weight:600}.file-selected-size{color:var(--muted);font-variant-numeric:tabular-nums;font-size:.72rem}.file-selected-clear{color:var(--muted);cursor:pointer;border-radius:var(--radius);background:0 0;border:none;align-items:center;padding:.3rem;transition:background .12s,color .12s;display:flex}.file-selected-clear:hover{background:var(--danger-bg);color:var(--danger)}.form-section{flex-direction:column;gap:.85rem;display:flex}.form-section-title{text-transform:uppercase;letter-spacing:.15em;color:var(--accent);border-bottom:1px solid var(--border-soft);padding-bottom:.4rem;font-size:.68rem;font-weight:700}.field-grid{grid-template-columns:repeat(3,1fr);gap:.85rem;display:grid}.required-star{color:var(--danger);margin-left:.2rem}.progress-wrap{flex-direction:column;gap:.4rem;display:flex}.progress-meta{color:var(--muted);font-variant-numeric:tabular-nums;justify-content:space-between;font-size:.78rem;display:flex}.progress-bar{background:var(--surface-hov);border-radius:var(--radius-pill);width:100%;height:5px;overflow:hidden}.progress-bar-fill{background:var(--accent);height:100%;transition:width .25s}.dashboard-page,.shipment-list-page,.shipment-detail-page{max-width:1100px}.dashboard-header,.detail-header{flex-wrap:wrap;justify-content:space-between;align-items:flex-start;gap:1rem;display:flex}.dashboard-actions{flex-wrap:wrap;gap:.55rem;display:flex}.back-link{color:var(--text-mute);border-radius:var(--radius);align-items:center;gap:.4rem;margin-bottom:.85rem;margin-left:-.25rem;padding:.3rem .6rem .3rem .25rem;font-size:.95rem;font-weight:600;text-decoration:none;transition:background .12s,color .12s;display:inline-flex}.back-link:hover{color:var(--accent);background:var(--accent-bg)}.stat-grid{grid-template-columns:repeat(3,1fr);gap:1rem;margin-bottom:1.85rem;display:grid}.stat-grid-4{grid-template-columns:repeat(4,1fr)}.stat-card{background:var(--surface);border:1px solid var(--border-soft);border-radius:var(--radius-lg);box-shadow:var(--shadow-xs);flex-direction:column;gap:.5rem;padding:1.2rem 1.3rem 1.1rem;display:flex;position:relative}.stat-card-label{color:var(--muted);letter-spacing:.1em;text-transform:uppercase;align-items:center;gap:.45rem;font-size:.7rem;font-weight:600;display:flex}.stat-card-value{color:var(--text);letter-spacing:-.02em;font-variant-numeric:tabular-nums lining-nums;font-size:1.85rem;font-weight:700;line-height:1.1}.stat-card-ok .stat-card-value,.stat-card-ok .stat-card-label{color:var(--success)}.stat-card-danger .stat-card-value,.stat-card-danger .stat-card-label{color:var(--danger)}.stat-card-info .stat-card-value,.stat-card-info .stat-card-label{color:var(--info)}.dashboard-section{margin-bottom:2rem}.section-header{justify-content:space-between;align-items:baseline;margin-bottom:.8rem;display:flex}.section-title{color:var(--text);letter-spacing:-.01em;font-size:1.05rem;font-weight:700}.section-meta{color:var(--muted);font-variant-numeric:tabular-nums;font-size:.78rem}.section-header-right{flex-wrap:wrap;justify-content:flex-end;align-items:center;gap:.65rem;display:inline-flex}.interval-badge{border-radius:var(--radius-pill);background:var(--accent-bg);color:var(--accent);border:1px solid var(--accent-line);letter-spacing:.01em;white-space:nowrap;align-items:center;gap:.35rem;padding:.2rem .6rem .2rem .5rem;font-size:.74rem;font-weight:600;display:inline-flex}.interval-badge>svg{flex-shrink:0}.section-link{color:var(--accent);font-size:.82rem;font-weight:600;text-decoration:none}.section-link:hover{text-underline-offset:3px;text-decoration:underline}.alert{border-radius:var(--radius);margin-bottom:1rem;padding:.75rem .95rem;font-size:.85rem}.alert-danger{background:var(--danger-bg);color:var(--danger);border:1px solid #f4c5ce}.search-row{margin-bottom:1rem}.search-input-wrap{max-width:420px;position:relative}.search-icon{color:var(--muted);pointer-events:none;position:absolute;top:50%;left:.7rem;transform:translateY(-50%)}.search-input{background:var(--surface);padding-left:2.1rem}.loading-row{color:var(--muted);align-items:center;gap:.55rem;padding:1.1rem 0;font-size:.875rem;display:flex}.table-wrap{background:var(--surface);border:1px solid var(--border-soft);border-radius:var(--radius-lg);box-shadow:var(--shadow-xs);overflow:hidden}.data-table{border-collapse:collapse;width:100%;font-size:.875rem}.data-table thead{background:var(--surface-2);text-transform:uppercase;letter-spacing:.1em;color:var(--muted);border-bottom:1px solid var(--border-soft);font-size:.68rem}.data-table th,.data-table td{text-align:left;vertical-align:middle;padding:.8rem 1rem}.data-table th{font-weight:700}.data-table tbody tr{border-top:1px solid var(--border-soft);transition:background .1s}.data-table tbody tr:first-child{border-top:none}.data-table tbody tr:hover{background:var(--surface-2)}.data-table tbody tr.row-clickable{cursor:pointer}.data-table tbody tr.row-clickable:focus-visible{outline:2px solid var(--accent);outline-offset:-2px}.data-table tbody tr.row-clickable:hover .row-link{background:var(--accent-bg);color:var(--accent)}.cell-strong{color:var(--text);font-weight:600}.cell-muted{color:var(--muted);font-variant-numeric:tabular-nums}.cell-action{text-align:right;width:36px}.row-link{border-radius:var(--radius);width:26px;height:26px;color:var(--muted);justify-content:center;align-items:center;transition:background .12s,color .12s;display:inline-flex}.row-link:hover{background:var(--accent-bg);color:var(--accent)}.alarm-badge{border-radius:var(--radius-pill);text-transform:uppercase;letter-spacing:.06em;vertical-align:middle;border:1px solid #0000;align-items:center;gap:.4rem;margin-left:.55rem;padding:.18rem .6rem .18rem .5rem;font-size:.7rem;font-weight:600;display:inline-flex}.alarm-badge:before{content:"";border-radius:50%;flex-shrink:0;width:6px;height:6px}.alarm-badge-ok{background:var(--success-bg);color:var(--success);border-color:#b7e1c8}.alarm-badge-ok:before{background:var(--success)}.alarm-badge-danger{background:var(--danger-bg);color:var(--danger);border-color:#f4c5ce}.alarm-badge-danger:before{background:var(--danger)}.source-pill{background:var(--accent-bg);color:var(--accent);text-transform:uppercase;letter-spacing:.08em;font-size:.66rem;font-weight:600;font-family:var(--mono);border-radius:4px;padding:.12rem .45rem;display:inline-block}.info-grid{grid-template-columns:repeat(2,1fr);gap:1rem;display:grid}.info-card{background:var(--surface);border:1px solid var(--border-soft);border-radius:var(--radius-lg);box-shadow:var(--shadow-xs);padding:1.4rem 1.5rem}.info-list{flex-direction:column;gap:.55rem;margin-top:.4rem;display:flex}.info-row{grid-template-columns:145px 1fr;align-items:baseline;gap:.5rem;display:grid}.info-row dt{color:var(--muted);text-transform:uppercase;letter-spacing:.08em;font-size:.72rem;font-weight:600}.info-row dd{color:var(--text);word-break:break-word;font-size:.88rem}.chart-wrap{flex-direction:column;gap:.95rem;width:100%;display:flex}.chart-empty{color:var(--muted);text-align:center;padding:2.5rem;font-size:.88rem}.chart-toolbar{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:1rem;display:flex}.chart-controls{flex-wrap:wrap;align-items:center;gap:.75rem;display:inline-flex}.chart-control{align-items:center;gap:.5rem;display:inline-flex}.chart-control-label{letter-spacing:.1em;text-transform:uppercase;color:var(--muted);font-size:.68rem;font-weight:600}.chart-select{background:var(--surface);cursor:pointer;width:auto;min-width:140px;padding:.4rem .7rem;font-size:.85rem}.chart-number-input{background:var(--surface);font-variant-numeric:tabular-nums;width:92px;padding:.4rem .65rem;font-size:.85rem}.chart-number-input::placeholder{color:var(--faint)}.chart-number-input.input-override{border:1px solid var(--accent);background:var(--accent-bg);color:var(--accent);font-weight:600}.chart-number-input::-webkit-outer-spin-button{appearance:none;margin:0}.chart-number-input::-webkit-inner-spin-button{appearance:none;margin:0}.chart-number-input[type=number]{appearance:textfield}.chart-stats{color:var(--text);align-items:center;gap:1.25rem;font-size:.82rem;display:inline-flex}.chart-stats>span{color:var(--muted);align-items:baseline;gap:.35rem;display:inline-flex}.chart-stats strong{color:var(--text);margin-left:.05rem;font-weight:600}.chart-stats-meta{color:var(--faint)!important}.unit-toggle{background:var(--surface-2);border:1px solid var(--border-soft);border-radius:var(--radius);padding:3px;display:inline-flex}.unit-toggle-btn{font:inherit;cursor:pointer;color:var(--muted);background:0 0;border:none;border-radius:5px;padding:4px 12px;font-size:.78rem;font-weight:600;transition:background .12s,color .12s}.unit-toggle-btn:hover:not(.active){color:var(--text)}.unit-toggle-btn.active{background:var(--surface);color:var(--accent);box-shadow:var(--shadow-xs)}.chart-tooltip{border:1px solid var(--border);border-radius:var(--radius);background:#fff;min-width:170px;padding:.55rem .7rem;font-family:inherit;font-size:12px;box-shadow:0 8px 24px -8px #16182e2e}.chart-tooltip-label{color:var(--muted);margin-bottom:.35rem;font-size:.72rem;font-weight:600}.chart-tooltip-row{color:var(--text);align-items:center;gap:.45rem;padding:.1rem 0;display:flex}.chart-tooltip-row strong{margin-left:auto;font-weight:600}.chart-tooltip-row .dot{border-radius:50%;width:8px;height:8px;display:inline-block}.chart-tooltip-row .dot-avg{background:#1f3a8a}.analysis-grid{grid-template-columns:repeat(2,minmax(0,1fr));align-items:stretch;gap:1rem;display:grid}.analysis-grid>.daily-card{grid-column:1/-1}.zone-card{background:var(--surface);border:1px solid var(--border-soft);border-radius:var(--radius-lg);box-shadow:var(--shadow-xs);flex-direction:column;gap:.85rem;padding:1.25rem 1.4rem;display:flex}.zone-card-header{justify-content:space-between;align-items:baseline;display:flex}.zone-card-title{color:var(--text);letter-spacing:-.01em;font-size:.95rem;font-weight:700}.zone-card-meta{color:var(--muted);font-variant-numeric:tabular-nums;font-size:.74rem}.zone-card-body{grid-template-columns:180px 1fr;align-items:center;gap:1rem;display:grid}.zone-chart{height:180px;position:relative}.zone-chart-center{pointer-events:none;flex-direction:column;justify-content:center;align-items:center;display:flex;position:absolute;inset:0}.zone-chart-center-value{color:var(--text);letter-spacing:-.02em;font-size:1.5rem;font-weight:700;line-height:1}.zone-chart-center-label{text-transform:uppercase;letter-spacing:.1em;color:var(--muted);margin-top:.25rem;font-size:.7rem;font-weight:600}.zone-legend{flex-direction:column;gap:.5rem;list-style:none;display:flex}.zone-legend li{color:var(--text);grid-template-columns:14px 1fr auto;align-items:center;gap:.55rem;font-size:.85rem;display:grid}.zone-swatch{border-radius:3px;width:10px;height:10px;display:inline-block}.zone-name{color:var(--text-mute)}.zone-value{font-weight:600}.zone-thresholds{color:var(--muted);border-top:1px dashed var(--border-soft);gap:1rem;padding-top:.4rem;font-size:.78rem;display:flex}.zone-thresholds strong{color:var(--text);font-weight:600}.zone-stat{flex-direction:column;flex:1;justify-content:center;align-items:flex-start;gap:.35rem;padding:.5rem 0;display:flex}.zone-stat-value{color:var(--accent);letter-spacing:-.02em;font-size:2.5rem;font-weight:700;line-height:1}.zone-stat-label{color:var(--muted);text-transform:uppercase;letter-spacing:.08em;font-size:.78rem;font-weight:600}.daily-card{background:var(--surface);border:1px solid var(--border-soft);border-radius:var(--radius-lg);box-shadow:var(--shadow-xs);padding:1.25rem 1.4rem}.daily-strip{grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:.65rem;margin-top:.85rem;display:grid}.daily-tile{background:var(--surface-2);border:1px solid var(--border-soft);border-radius:var(--radius);flex-direction:column;gap:.2rem;padding:.65rem .75rem;font-size:.78rem;display:flex}.daily-tile-alarm{background:var(--danger-bg);border-color:#f4c5ce}.daily-date{color:var(--text);margin-bottom:.3rem;font-size:.82rem;font-weight:600}.daily-row{color:var(--text-mute);justify-content:space-between;align-items:baseline;display:flex}.daily-label{color:var(--muted);text-transform:uppercase;letter-spacing:.04em;font-size:.7rem;font-weight:600}.daily-points{color:var(--muted);border-top:1px dashed var(--border-soft);margin-top:.3rem;padding-top:.3rem;font-size:.7rem}.alert-warning{background:var(--warning-bg);color:var(--warning);border:1px solid #ead0a3}@media (width<=768px){.analysis-grid,.zone-card-body{grid-template-columns:1fr}}.pagination{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:1rem;margin-top:.85rem;padding:.25rem .1rem;display:flex}.pagination-summary{color:var(--muted);font-size:.78rem}.pagination-controls{background:var(--surface);border:1px solid var(--border-soft);border-radius:var(--radius);box-shadow:var(--shadow-xs);align-items:center;gap:2px;padding:3px;display:inline-flex}.pagination-btn{min-width:28px;height:28px;color:var(--text-mute);cursor:pointer;font-variant-numeric:tabular-nums;background:0 0;border:none;border-radius:5px;justify-content:center;align-items:center;padding:0 .55rem;font-family:inherit;font-size:.82rem;font-weight:500;transition:background .12s,color .12s;display:inline-flex}.pagination-btn:hover:not(:disabled):not(.active){background:var(--surface-hov);color:var(--text)}.pagination-btn:disabled{opacity:.4;cursor:not-allowed}.pagination-btn.active{background:var(--accent);color:#fff;cursor:default}.pagination-ellipsis{min-width:24px;height:28px;color:var(--faint);-webkit-user-select:none;user-select:none;justify-content:center;align-items:center;font-size:.8rem;display:inline-flex}@media (width<=960px){.auth-page{grid-template-columns:1fr}.auth-hero{min-height:220px;padding:2rem 1.5rem}.auth-hero-headline{font-size:1.5rem}}@media (width<=768px){:root{--sidebar-w:0px}.sidebar{flex-flow:wrap;width:100%;height:auto;position:relative}.main-content{margin-left:0;padding:1.5rem}.profile-layout,.field-grid,.stat-grid,.stat-grid-4,.info-grid{grid-template-columns:1fr}.page-title{font-size:1.45rem}}
