:root {
  color-scheme: dark;
  --bg:#0f1117; --surface:#1a1d27; --card:#21253a;
  --accent2:#43e97b;
  --text:#e8eaf6; --muted:#b8bcc8; --border:#2e3250;
  --danger:#ff6b6b; --warn:#ffd166;
  /* Spacing scale */
  --s1:.1rem;--s2:.2rem;--s3:.3rem;--s4:.38rem;--s5:.45rem;--s6:.55rem;--s7:.65rem;--s8:.75rem;--s9:.9rem;--s10:1rem;--s11:1.1rem;--s12:1.25rem;
  /* Border radius scale */
  --radius-lg:14px;--radius-md:10px;--radius-sm:8px;--radius-xs:2px;--radius-sm-md:6px;--radius-pill:99px;--radius-circle:50%;--radius-icon:15px;
  /* Shadow & overlay tokens */
  --shadow-light:rgba(0,0,0,.14);--shadow-medium:rgba(0,0,0,.18);--shadow-strong:rgba(0,0,0,.22);--shadow-dark:rgba(0,0,0,.55);--overlay-modal:rgba(0,0,0,.6);--overlay-bg:rgba(0,0,0,.44);
  /* Warning state tokens (derived from --warn) */
  --warn-bg:rgba(255,209,102,.12);--warn-border:rgba(255,209,102,.25);
  /* Line height & dot sizes */
  --lh:1.6;--dot-sm:5px;--dot-md:7px;--dot-lg:9px;
  /* Structural sizes */
  --nav-height:52px;--notif-popup-w:310px;--notif-popup-max-h:260px;--tooltip-width:260px;--swipe-width:70px;--swipe-width-narrow:60px;
  --badge-size:7px;--icon-sm:16px;--icon-md:18px;--icon-lg:20px;--icon-nav:23px;--content-max-w:960px;
  /* Toggle sizes */
  --toggle-knob:#fff;--toggle-width:40px;--toggle-height:22px;--toggle-shift:18px;
  /* Letter spacing */
  --tracking-sm:.3px;--tracking-md:.5px;--tracking-lg:.6px;
}
*{box-sizing:border-box;margin:0;padding:0;}
*{scrollbar-width:none;-ms-overflow-style:none;}*::-webkit-scrollbar{display:none;width:0;height:0;}
html{touch-action:pan-x pan-y;width:100%;}
body{font-family:'Segoe UI',system-ui,sans-serif;background:var(--bg);color:var(--text);width:100%;min-height:100vh;-webkit-user-select:none;user-select:none;-webkit-touch-callout:none;-webkit-tap-highlight-color:transparent;}
input,textarea,select{-webkit-user-select:text;user-select:text;}

/* SMART SETTINGS TOGGLES */
.setting-row{display:flex;align-items:flex-start;justify-content:space-between;gap:var(--s10);padding:var(--s8) 0;border-bottom:1px solid var(--border);}
.setting-row:last-child{border-bottom:none;padding-bottom:0;}
.setting-row-disabled{opacity:.5;pointer-events:none;cursor:not-allowed;}
.setting-label{flex:1;min-width:0;}
.setting-label strong{font-size:.82rem;font-weight:700;display:block;margin-bottom:var(--s1);}
.setting-label span{font-size:.68rem;color:var(--muted);line-height:1.5;}
.setting-right{display:flex;align-items:center;gap:var(--s6);flex-shrink:0;}
/* pill toggle */
.sw{position:relative;width:var(--toggle-width);height:var(--toggle-height);flex-shrink:0;}
.sw input{opacity:0;width:0;height:0;position:absolute;}
.sw-track{position:absolute;inset:0;background:var(--border);border-radius:var(--radius-pill);transition:background .2s;cursor:pointer;}
.sw input:checked + .sw-track{background:var(--accent2);}
.sw-track::after{content:'';position:absolute;width:16px;height:16px;background:var(--toggle-knob);border-radius:var(--radius-circle);top:3px;left:3px;transition:transform .2s;}
.sw input:checked + .sw-track::after{transform:translateX(var(--toggle-shift));}
/* info bubble */
.info-bubble{position:relative;display:inline-flex;align-items:center;justify-content:center;min-width:44px;min-height:44px;border-radius:var(--radius-circle);background:var(--surface);border:1px solid var(--border);color:var(--muted);font-size:.62rem;font-weight:800;cursor:pointer;flex-shrink:0;user-select:none;overflow:visible;}
.info-bubble.open .info-tooltip{display:block;}
.info-tooltip{display:none;position:absolute;right:calc(100% + var(--s8));top:50%;transform:translateY(-50%);width:var(--tooltip-width);background:var(--card);border:1px solid var(--border);border-radius:var(--radius-md);padding:var(--s7) var(--s8);font-size:.7rem;color:var(--text);line-height:var(--lh);z-index:9999;box-shadow:0 6px 24px #000a;white-space:normal;pointer-events:none;}
.info-tooltip .tip-desc{margin-bottom:0;}
.info-tooltip .conflict-note{color:var(--warn);margin-top:var(--s6);padding-top:var(--s5);border-top:1px solid var(--border);font-weight:600;font-size:.68rem;line-height:var(--lh);}

/* Skip link — visually hidden until focused (H-A11Y-08) */
.skip-link{position:absolute;top:-100%;left:0;padding:.5rem 1rem;background:var(--accent2);color:var(--bg);font-weight:700;font-size:.875rem;border-radius:0 0 var(--radius-sm) 0;z-index:10000;text-decoration:none;}
.skip-link:focus{top:0;}

nav{position:relative;z-index:100;background:var(--card);border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:center;height:var(--nav-height);box-shadow:0 2px 12px #0005;}
.nav-brand{font-size:.95rem;font-weight:800;letter-spacing:var(--tracking-sm);pointer-events:none;white-space:nowrap;}
.nav-brand .brand-better{color:var(--text);}
.nav-brand .brand-choices{color:var(--accent2);}

/* BOTTOM NAV */
.bottom-nav{position:fixed;top:auto;bottom:0;left:0;right:0;z-index:100;background:var(--card);border-top:1px solid var(--border);border-bottom:none;display:flex;align-items:stretch;padding-bottom:calc(var(--s9) + env(safe-area-inset-bottom,0px));box-shadow:0 -2px 16px #0007;min-height:calc(60px + env(safe-area-inset-bottom,0px));}
.bnav-tab{flex:1;height:var(--nav-height);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--s4);background:none;border:none;cursor:pointer;color:var(--muted);padding:var(--s5) 0 var(--s5);transition:color .15s;}
.bnav-tab svg{width:var(--icon-nav);height:var(--icon-nav);flex-shrink:0;stroke:currentColor;fill:none;stroke-width:1.75;stroke-linecap:round;stroke-linejoin:round;}
.bnav-tab span{font-size:.58rem;font-weight:700;text-transform:uppercase;letter-spacing:var(--tracking-lg);}
.bnav-tab.active{color:var(--accent2);}
.bnav-tab:hover:not(.active){color:var(--text);}

/* TOP NAV BACK BUTTON */
.topnav-back-btn{position:absolute;left:var(--s8);top:50%;transform:translateY(-50%);background:none;border:none;cursor:pointer;color:var(--text);padding:var(--s10);min-width:44px;min-height:44px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-sm);transition:background .15s;}
.topnav-back-btn:hover{background:var(--surface);}
.topnav-back-btn svg{stroke:currentColor;fill:none;stroke-linecap:round;stroke-linejoin:round;}
/* PANEL BACK BUTTON (inline variant of topnav-back-btn for full-screen panels) */
.panel-icon-back{background:none;border:none;cursor:pointer;color:var(--text);padding:var(--s10);min-width:44px;min-height:44px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-sm);transition:background .15s;flex-shrink:0;}
.panel-icon-back:hover{background:var(--surface);}
.panel-icon-back svg{stroke:currentColor;fill:none;stroke-linecap:round;stroke-linejoin:round;}

/* NOTIFICATION BELL */
.notif-bell{position:absolute;right:var(--s8);top:50%;transform:translateY(-50%);background:none;border:none;cursor:pointer;color:var(--text);padding:var(--s10);min-width:44px;min-height:44px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-circle);transition:background .15s;}
.notif-bell:hover{background:var(--surface);}
.notif-bell svg{width:var(--icon-lg);height:var(--icon-lg);stroke:currentColor;fill:none;stroke-width:1.75;stroke-linecap:round;stroke-linejoin:round;}
.notif-badge{position:absolute;top:4px;right:4px;background:var(--danger);border-radius:var(--radius-circle);width:var(--badge-size);height:var(--badge-size);border:1.5px solid var(--card);}
/* NOTIFICATION DROPDOWN */
.notif-dropdown{position:absolute;top:calc(100% + 4px);right:.5rem;width:min(var(--notif-popup-w),92vw);background:var(--card);border:1px solid var(--border);border-radius:var(--radius-md);box-shadow:0 8px 32px #000c;z-index:500;overflow:hidden;display:none;}
.notif-dropdown.open{display:block;}
.notif-drop-hdr{display:flex;justify-content:space-between;align-items:center;padding:var(--s7) var(--s9);border-bottom:1px solid var(--border);}
.notif-drop-hdr span{font-size:.78rem;font-weight:700;}
.notif-drop-viewall{background:none;border:none;color:var(--accent2);font-size:.72rem;font-weight:600;cursor:pointer;padding:var(--s2) var(--s3);}
.notif-drop-list{max-height:var(--notif-popup-max-h);overflow-y:auto;scrollbar-width:none;-ms-overflow-style:none;}
.notif-item{display:flex;align-items:flex-start;gap:var(--s6);padding:var(--s7) var(--s9);cursor:pointer;border-bottom:1px solid var(--border);transition:background .12s;}
.notif-item:last-child{border-bottom:none;}
.notif-item:hover{background:var(--surface);}
.notif-item-icon{font-size:1.1rem;flex-shrink:0;margin-top:var(--s1);}
.notif-item-body{flex:1;min-width:0;}
.notif-item-title{font-size:.76rem;font-weight:700;color:var(--text);margin-bottom:var(--s1);}
.notif-item-preview{font-size:.68rem;color:var(--muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.notif-item-date{font-size:.6rem;color:var(--muted);margin-top:var(--s1);}
.notif-item-dot{width:var(--dot-md);height:var(--dot-md);border-radius:var(--radius-circle);background:var(--accent2);flex-shrink:0;margin-top:5px;}
.notif-empty{text-align:center;padding:var(--s12);font-size:.78rem;color:var(--muted);}
/* NOTIFICATION PANEL + DETAIL */
.notif-panel{position:fixed;inset:0;z-index:1500;background:var(--bg);display:flex;flex-direction:column;transform:translateX(100%);transition:transform .25s ease;}
.notif-panel.open{transform:translateX(0);}
.notif-panel-hdr{display:flex;align-items:center;gap:var(--s8);padding:var(--s9) var(--s10);border-bottom:1px solid var(--border);background:var(--card);}
.notif-panel-back{background:none;border:1px solid var(--border);color:var(--muted);font-size:.82rem;font-weight:600;cursor:pointer;padding:var(--s2) var(--s6);border-radius:var(--radius-pill);flex-shrink:0;}
.notif-panel-back:hover{background:var(--border);color:var(--text);}
.notif-panel-title{font-size:.95rem;font-weight:800;flex:1;}
.notif-panel-markall{background:none;border:none;color:var(--accent2);font-size:.72rem;font-weight:600;cursor:pointer;}
.notif-panel-list{flex:1;overflow-y:auto;padding:var(--s8);scrollbar-width:none;-ms-overflow-style:none;}
.notif-detail-overlay{position:fixed;inset:0;z-index:1600;background:var(--bg);display:flex;flex-direction:column;transform:translateX(100%);transition:transform .25s ease;}
.notif-detail-overlay.open{transform:translateX(0);}
.notif-detail-body{flex:1;overflow-y:auto;padding:var(--s10);scrollbar-width:none;-ms-overflow-style:none;}
.notif-drop-list::-webkit-scrollbar,.notif-panel-list::-webkit-scrollbar,.notif-detail-body::-webkit-scrollbar{display:none;width:0;}

/* LAYOUT */
main{max-width:var(--content-max-w);margin:0 auto;padding:var(--s12) var(--s8) calc(68px + env(safe-area-inset-bottom,0px) + var(--s12));}
section{display:none;}
section.active{display:block;}
h2{font-size:1.15rem;font-weight:700;margin-bottom:var(--s10);}
h3{font-size:.85rem;color:var(--text);margin-bottom:var(--s6);font-weight:700;}

/* CARDS */
.card{background:var(--card);border:1px solid var(--border);border-radius:var(--radius-lg);padding:var(--s11);margin-bottom:var(--s10);}
.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:var(--s8);}
@media(max-width:480px){.grid-2{grid-template-columns:1fr;}}

/* FORMS */
label{display:block;font-size:.68rem;color:var(--muted);margin-bottom:var(--s2);font-weight:600;text-transform:uppercase;letter-spacing:var(--tracking-md);}
input:not([type="hidden"]):not([type="checkbox"]):not([type="radio"]):not([type="submit"]):not([type="button"]):not([type="range"]),select{width:100%;min-width:0;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text);padding:var(--s7) var(--s9);font-size:.9rem;line-height:1;height:2.75rem;transition:border-color .2s;appearance:none;-webkit-appearance:none;}
input[type=”date”]::-webkit-calendar-picker-indicator{filter:invert(.6);}
input:not([type=”hidden”]):not([type=”checkbox”]):not([type=”radio”]):not([type=”submit”]):not([type=”button”]):not([type=”range”]):focus,select:focus{outline:none;border-color:var(--accent2);}
input:-webkit-autofill,input:-webkit-autofill:hover,input:-webkit-autofill:focus,input:-webkit-autofill:active{-webkit-box-shadow:0 0 0 1000px var(--surface) inset!important;-webkit-text-fill-color:var(--text)!important;caret-color:var(--text);}
select{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 12 8'%3E%3Cpath d='M1 1.5l5 5 5-5' stroke='%2343e97b' stroke-width='2' fill='none' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right .75rem center;background-size:12px 8px;padding-right:2.4rem;}
.btn{padding:var(--s5) var(--s9);border-radius:var(--radius-sm);border:none;font-size:.78rem;font-weight:600;cursor:pointer;transition:opacity .2s,transform .1s;white-space:nowrap;}
.btn:active{transform:scale(.97);}
.btn-primary{background:var(--accent2);color:#000;}
.btn-success{background:var(--accent2);color:#000;}
.btn-danger{background:var(--danger);color:#fff;}
.btn-ghost{background:transparent;border:1px solid var(--border);color:var(--muted);}
.btn-sm{padding:.3rem .55rem;font-size:.75rem;}
.btn:hover{opacity:.85;}
.btn:disabled{opacity:.4;cursor:not-allowed;}

/* STATS */
.stats-row{display:flex;gap:var(--s7);margin-bottom:var(--s10);flex-wrap:wrap;}
.stat{background:var(--card);border:1px solid var(--border);border-radius:var(--radius-md);padding:var(--s7) var(--s9);flex:1;min-width:110px;text-align:center;}
.stat-value{font-size:1.05rem;font-weight:700;color:var(--accent2);}
.stat-label{font-size:.6rem;color:var(--muted);margin-top:var(--s1);text-transform:uppercase;letter-spacing:var(--tracking-sm);}

/* ALERT / INFO */
.info-box{background:var(--bg);border-radius:var(--radius-sm);padding:var(--s6) var(--s8);font-size:.75rem;color:var(--muted);line-height:var(--lh);}
.info-box strong{color:var(--text);}
.alert{border-radius:var(--radius-sm);padding:var(--s6) var(--s9);font-size:.75rem;line-height:var(--lh);font-weight:600;}
.alert-danger{background:#ff6b6b18;border:1px solid #ff6b6b44;color:var(--danger);}
.alert-warn{background:#ffd16618;border:1px solid #ffd16644;color:var(--warn);}
.alert-ok{background:#43e97b18;border:1px solid #43e97b44;color:var(--accent2);}
.divider{height:1px;background:var(--border);margin:var(--s6) 0;}
.empty-state{text-align:center;padding:var(--s12);color:var(--muted);font-size:.82rem;}

/* FORM VALIDATION */
.field-group{position:relative;margin-bottom:var(--s6);}
.input-error,input.input-error,select.input-error,textarea.input-error{border-color:var(--danger);background:color-mix(in srgb, var(--danger) 5%, var(--surface));}
.input-error:focus{outline-color:var(--danger);box-shadow:0 0 0 3px color-mix(in srgb, var(--danger) 15%, transparent);}
.form-error-message{font-size:.7rem;color:var(--danger);margin-top:var(--s3);padding-left:var(--s2);display:none;line-height:1.3;}
.form-error-message.visible{display:block;}
.form-error-icon{display:inline-block;margin-right:var(--s2);}
input[aria-invalid="true"],select[aria-invalid="true"],textarea[aria-invalid="true"]{border-color:var(--danger);}

/* KEYBOARD FOCUS INDICATORS */
*:focus-visible{outline:2px solid var(--accent2);outline-offset:2px;}

/* DONUT */
.donut-wrap{display:flex;align-items:center;gap:var(--s11);flex-wrap:wrap;}
.donut-legend{display:flex;flex-direction:column;gap:var(--s4);flex:1;min-width:130px;}
.dleg{display:flex;align-items:center;gap:var(--s4);font-size:.74rem;}
.dleg-dot{width:var(--dot-lg);height:var(--dot-lg);border-radius:var(--radius-circle);flex-shrink:0;}
.dleg-val{margin-left:auto;font-weight:700;font-size:.74rem;}

/* POOL BAR */
.cbudget-bar-wrap{background:var(--bg);border-radius:var(--radius-pill);height:18px;overflow:hidden;margin:var(--s6) 0 var(--s3);}
.cbudget-segments{display:flex;height:100%;}
.cbudget-seg{height:100%;transition:width .4s ease;}
.cbudget-legend{display:flex;flex-wrap:wrap;gap:var(--s3) var(--s6);font-size:.68rem;margin-top:var(--s3);}
.cbleg{display:flex;align-items:center;gap:var(--s3);font-size:.72rem;}
.cbleg-dot{width:var(--dot-md);height:var(--dot-md);border-radius:var(--radius-circle);flex-shrink:0;}

/* POCKETS */
/* Pocket card redesign */
.pc-hdr{display:flex;justify-content:space-between;align-items:center;gap:var(--s4);cursor:pointer;user-select:none;}
.pc-hdr-left{display:flex;align-items:center;gap:var(--s6);flex:1;min-width:0;}
.pc-hdr-right{display:flex;gap:var(--s2);align-items:center;flex-shrink:0;}
.pc-chevron{font-size:.58rem;color:var(--accent2);flex-shrink:0;transition:transform .18s;line-height:1;}
.pc-emoji{font-size:1.05rem;flex-shrink:0;}
.pc-meta{min-width:0;}
.pc-name{font-weight:700;font-size:.85rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.pc-sub{font-size:.62rem;color:var(--muted);margin-top:var(--s1);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.pc-body{margin-top:var(--s7);}
.pc-bar-wrap{background:var(--bg);border-radius:var(--radius-pill);height:5px;overflow:hidden;margin-bottom:var(--s3);}
.pc-bar{height:100%;border-radius:var(--radius-pill);transition:width .4s;}
.pc-bar-stats{display:flex;align-items:baseline;gap:var(--s3);margin-bottom:var(--s3);}
.pc-stat-n{font-size:.8rem;font-weight:800;}
.pc-stat-sep{font-size:.7rem;color:var(--border);}
.pc-stat-l{font-size:.63rem;color:var(--muted);}
.pc-flags{display:flex;flex-wrap:wrap;gap:var(--s2);margin-bottom:var(--s3);}
.pc-section-btn{width:100%;background:none;border:none;padding:var(--s5) 0 0;display:flex;align-items:center;justify-content:space-between;cursor:pointer;min-height:36px;}
.pc-section-lbl{font-size:.6rem;font-weight:700;text-transform:uppercase;letter-spacing:var(--tracking-lg);color:var(--muted);}
.pc-section-chev{font-size:.55rem;color:var(--accent2);transition:transform .18s;}
.pc-row{display:flex;align-items:center;gap:var(--s5);padding:var(--s3) 0;border-bottom:1px solid var(--border);}
.pc-row:last-child{border-bottom:none;}
.pc-row-icon{font-size:.88rem;flex-shrink:0;}
.pc-row-name{flex:1;font-size:.74rem;font-weight:600;}
.pc-row-sub{font-size:.62rem;color:var(--muted);}
.pc-row-amt{font-size:.74rem;font-weight:700;color:var(--accent2);flex-shrink:0;}
.pc-summary{display:flex;justify-content:space-between;align-items:center;padding:var(--s3) var(--s6);background:var(--bg);border-radius:var(--radius-sm);margin-top:var(--s3);}
.pc-summary-lbl{font-size:.62rem;font-weight:700;text-transform:uppercase;letter-spacing:var(--tracking-sm);color:var(--muted);}
.pc-summary-val{font-size:.88rem;font-weight:800;color:var(--accent2);}
.pc-sub-hdr{display:flex;justify-content:space-between;align-items:center;padding:var(--s3) 0;border-top:1px solid var(--border);margin-top:var(--s3);}
.pc-sub-lbl{font-size:.6rem;font-weight:700;text-transform:uppercase;letter-spacing:var(--tracking-lg);color:var(--muted);}
.pc-sub-actions{display:flex;align-items:center;gap:var(--s4);}
.pc-sub-total-lbl{font-size:.68rem;}
.pc-no-amt-hint{font-size:.68rem;color:var(--muted);font-style:italic;padding:var(--s3) 0;}
.tag{display:inline-block;font-size:.63rem;padding:var(--s1) var(--s4);border-radius:var(--radius-pill);font-weight:700;white-space:nowrap;}
.tag-ok{background:#43e97b22;color:var(--accent2);}
.tag-warn{background:#ffd16622;color:var(--warn);border:1px solid #ffd16644;}
.tag-low{background:#ff6b6b22;color:var(--danger);}
.tag-close{background:#ffd16622;color:var(--warn);}
.tag-over{background:#ff6b6b22;color:var(--danger);border:1px solid #ff6b6b44;}

/* TYPE TOGGLE */
.type-toggle{display:flex;gap:var(--s3);}
.type-btn{flex:1;padding:var(--s5) var(--s4);border-radius:var(--radius-sm);border:2px solid var(--border);background:transparent;color:var(--muted);font-size:.74rem;font-weight:600;cursor:pointer;transition:all .2s;text-align:center;min-height:40px;}
.type-btn.aw{border-color:var(--accent2);background:#43e97b18;color:var(--text);}
.type-btn.af{border-color:var(--accent2);background:#43e97b18;color:var(--accent2);}
.type-btn:focus-visible{outline:2px solid var(--accent2);outline-offset:2px;}

/* SOURCE / EDIT */
.item-row{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-md);padding:var(--s8) var(--s9);margin-bottom:var(--s6);}
.item-row:last-child{margin-bottom:0;}
.item-header{display:flex;align-items:center;gap:var(--s6);flex-wrap:wrap;}
.item-name{font-weight:700;font-size:.85rem;flex:1;}
.item-meta{font-size:.7rem;color:var(--muted);margin-top:var(--s2);}
.item-actions{display:flex;gap:var(--s3);align-items:center;flex-shrink:0;}
.edit-form{background:transparent;border-radius:var(--radius-sm);padding:var(--s8) 0;margin-top:var(--s6);display:none;}
.edit-form.open{display:block;}

/* PAY CHIPS */
.pay-strip{display:flex;gap:var(--s3);flex-wrap:wrap;margin-top:var(--s4);}
.pay-chip{font-size:.63rem;padding:var(--s2) var(--s5);border-radius:var(--radius-sm-md);font-weight:700;white-space:nowrap;}
.pay-chip.cur{background:#43e97b22;color:var(--accent2);border:1px solid #43e97b44;}
.pay-chip.fut{background:#43e97b11;color:var(--accent2);border:1px solid #43e97b33;}
.pay-chip.p5{background:#ffd16622;color:var(--warn);border:1px solid #ffd16644;}

/* MONTH BANNER */
.month-banner{background:linear-gradient(135deg,#43e97b11,#38f9d711);border:1px solid #43e97b33;border-radius:var(--radius-md);padding:var(--s7) var(--s9);margin-top:var(--s7);}
.month-banner-title{font-size:.66rem;text-transform:uppercase;letter-spacing:var(--tracking-lg);color:var(--muted);font-weight:700;margin-bottom:var(--s3);}
.mb-row{display:flex;gap:var(--s10);flex-wrap:wrap;align-items:baseline;}
.mb-val{font-size:1.05rem;font-weight:800;color:var(--text);}
.mb-avg{font-size:.9rem;font-weight:700;color:var(--accent2);}
.mb-sub{font-size:.64rem;color:var(--muted);margin-top:var(--s1);}

/* BAR CHART */
.bar-chart{display:flex;flex-direction:column;gap:var(--s4);}
.bar-row{display:flex;align-items:center;gap:var(--s5);}
.bar-label{width:46px;text-align:right;color:var(--muted);flex-shrink:0;font-size:.67rem;}
.bar-outer{flex:1;background:var(--surface);border-radius:var(--radius-pill);height:19px;overflow:hidden;min-width:0;}
.bar-inner{height:100%;border-radius:var(--radius-pill);display:flex;align-items:center;padding-left:var(--s3);font-size:.62rem;font-weight:700;color:#fff;white-space:nowrap;min-width:4px;transition:width .5s;}
.bar-val{width:72px;color:var(--accent2);font-weight:700;text-align:right;font-size:.69rem;flex-shrink:0;}

/* EMOJI PICKER */
.emoji-cat-btn{background:none;border:none;padding:var(--s3) var(--s4);border-radius:var(--radius-sm);cursor:pointer;font-size:1.05rem;transition:background .15s;flex-shrink:0;}
.emoji-cat-btn:hover{background:var(--surface);}
.emoji-cat-btn.active{background:var(--border);}
.emoji-cell{background:none;border:none;font-size:1.35rem;padding:var(--s2);border-radius:var(--radius-sm);cursor:pointer;transition:background .15s;line-height:1;display:flex;align-items:center;justify-content:center;flex-shrink:0;}
.emoji-cell:hover{background:var(--surface);}
.emoji-cell:focus-visible{outline:2px solid var(--accent2);outline-offset:2px;}

/* POCKET FILTER */
.pkt-filter-btn{padding:var(--s5) var(--s9);border-radius:var(--radius-pill);border:1px solid var(--border);background:transparent;color:var(--muted);font-size:.76rem;font-weight:600;cursor:pointer;transition:all .2s;white-space:nowrap;min-height:36px;}
.pkt-filter-btn:hover{border-color:var(--accent2);color:var(--text);}
.pkt-filter-btn.active{background:var(--accent2);border-color:var(--accent2);color:#000;}
.pkt-filter-btn:focus-visible{outline:2px solid var(--accent2);outline-offset:2px;}

/* MODAL */
.modal-overlay{position:fixed;inset:0;z-index:2000;background:#000b;display:flex;align-items:center;justify-content:center;padding:var(--s10);}
.modal-box{background:var(--card);border:1px solid var(--border);border-radius:var(--radius-lg);padding:var(--s12);max-width:400px;width:100%;box-shadow:0 8px 40px #000c;animation:modalIn .15s ease;}
@keyframes modalIn{from{opacity:0;transform:scale(.96)}to{opacity:1;transform:scale(1)}}
.modal-msg{font-size:.85rem;line-height:var(--lh);margin-bottom:var(--s10);color:var(--text);}
.modal-btns{display:flex;gap:.5rem;justify-content:flex-end;}


/* TOOLS APP GRID */
.tools-app-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.2rem;padding:.5rem;}
@media(min-width:480px){.tools-app-grid{grid-template-columns:repeat(4,1fr);}}
.tool-app-item{display:flex;flex-direction:column;align-items:center;gap:.45rem;cursor:pointer;-webkit-tap-highlight-color:transparent;outline:none;border:none;background:none;}
.tool-app-item:focus-visible .tool-app-icon-bg{outline:2px solid var(--accent2);outline-offset:2px;}
.tool-app-item:active .tool-app-icon-bg{transform:scale(.9);}
.tool-app-icon-bg{width:62px;height:62px;border-radius:var(--radius-icon);background:var(--card);border:1px solid var(--border);box-shadow:0 2px 8px var(--shadow-medium);display:flex;align-items:center;justify-content:center;font-size:1.9rem;transition:transform .12s ease,box-shadow .12s ease;}
.tool-app-icon-bg:hover{box-shadow:0 4px 14px var(--shadow-strong);}
.tool-app-label{font-size:.72rem;font-weight:600;text-align:center;color:var(--text);max-width:80px;line-height:1.25;word-break:break-word;}
.tool-app-item--card{cursor:default;}
.tool-app-item--card:active .tool-app-icon-bg{transform:none;}
/* Tools view toggle */
.tools-view-toggle{display:flex;justify-content:flex-end;gap:.35rem;}
.tvt-btn{background:var(--card);border:1px solid var(--border);border-radius:var(--radius-sm);padding:.3rem .55rem;font-size:.75rem;cursor:pointer;color:var(--muted);-webkit-tap-highlight-color:transparent;line-height:1.4;}
.tvt-btn.active{background:var(--accent2);color:#000;border-color:var(--accent2);font-weight:700;}
/* Tools grid — 4-col mode */
.tools-app-grid.grid4{grid-template-columns:repeat(4,1fr);gap:.75rem;}
.tools-app-grid.grid4 .tool-app-icon-bg{width:62px;height:62px;font-size:1.8rem;}
.tools-app-grid.grid4 .tool-app-label{font-size:.65rem;max-width:70px;}
/* Tools list view (App Store style) */
.tools-list-view{display:flex;flex-direction:column;gap:var(--s7);}
.tools-list-item{display:flex;align-items:center;gap:var(--s9);padding:var(--s8) var(--s9);background:var(--card);border:1px solid var(--border);border-radius:var(--radius-md);cursor:pointer;-webkit-tap-highlight-color:transparent;transition:opacity .12s;}
.tools-list-item:active{opacity:.75;}
.tools-list-item--actions{cursor:default;}
.tools-list-item--actions:active{opacity:1;}
.tools-list-icon{width:50px;height:50px;border-radius:var(--radius-md);background:var(--surface);border:1px solid var(--border);display:flex;align-items:center;justify-content:center;font-size:1.55rem;flex-shrink:0;box-shadow:0 1px 4px var(--shadow-light);}
.tools-list-info{flex:1;min-width:0;}
.tools-list-name{font-weight:700;font-size:.85rem;color:var(--text);}
.tools-list-desc{font-size:.72rem;color:var(--muted);margin-top:var(--s2);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.tools-list-chevron{font-size:1.1rem;color:var(--muted);flex-shrink:0;padding-left:var(--s5);}
.tools-list-actions{display:flex;gap:.3rem;flex-wrap:wrap;}

/* SWIPE ACTIONS (swipe actions) */
.swipe-wrapper{position:relative;overflow:hidden;border-radius:var(--radius-lg);margin-bottom:var(--s8);transform:translateZ(0);}
.swipe-bg{position:absolute;top:0;height:100%;width:var(--swipe-width);display:flex;align-items:center;justify-content:center;font-size:.72rem;font-weight:700;cursor:pointer;user-select:none;-webkit-tap-highlight-color:transparent;z-index:1;}
.swipe-bg-edit{right:0;background:var(--accent2);color:#000;border-radius:0 var(--radius-lg) var(--radius-lg) 0;}
.swipe-bg-del{left:0;background:var(--danger);color:#fff;border-radius:var(--radius-lg) 0 0 var(--radius-lg);}
.swipe-card{position:relative;background:var(--card);z-index:2;}
.swipe-card.swipe-transitioning{transition:transform .35s ease-out;}
/* Pocket row swipe */
.swipe-wrapper-row{position:relative;overflow:hidden;border-radius:var(--radius-sm);transform:translateZ(0);}
.swipe-wrapper-row .swipe-bg{width:var(--swipe-width-narrow);}
.swipe-wrapper-row .swipe-bg-edit{border-radius:0 var(--radius-sm) var(--radius-sm) 0;}
.swipe-wrapper-row .swipe-bg-del{border-radius:var(--radius-sm) 0 0 var(--radius-sm);}
.cat-hdr-swipe{margin:calc(-1*var(--s9)) calc(-1*var(--s9)) var(--s7);border-radius:var(--radius-lg) var(--radius-lg) 0 0;}
.cat-hdr-swipe .swipe-card{padding:var(--s9);}


/* FORM POPUP OVERLAY */
.form-popup-overlay{position:fixed;inset:0;background:var(--overlay-modal);z-index:9000;display:flex;align-items:center;justify-content:center;padding:1rem;}
.form-popup-box{background:var(--surface);border-radius:var(--radius-lg);width:100%;max-width:520px;padding:1.1rem;max-height:88vh;overflow-y:auto;scrollbar-width:none;}
.form-popup-box::-webkit-scrollbar{display:none;}
.form-popup-hdr{display:flex;align-items:center;justify-content:space-between;margin-bottom:.75rem;}
.form-popup-hdr span{font-weight:700;font-size:.95rem;}
.form-popup-close{background:none;border:none;font-size:1.1rem;cursor:pointer;color:var(--muted);padding:.15rem .35rem;line-height:1;}

/* ACCESSIBILITY */
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0;}
button.as-div{background:none;border:none;padding:0;text-align:left;cursor:pointer;width:100%;font:inherit;color:inherit;}
button.as-div:focus-visible{outline:2px solid var(--accent2);outline-offset:2px;}

/* UTILITY CLASSES */
.row{display:flex;align-items:center;}
.row-between{display:flex;align-items:center;justify-content:space-between;}
.row-wrap{display:flex;align-items:center;flex-wrap:wrap;}
.col{display:flex;flex-direction:column;}
.gap-sm{gap:var(--s4);}
.gap-md{gap:var(--s7);}
.text-muted{color:var(--muted);}
.text-danger{color:var(--danger);}
.text-sm{font-size:var(--s7);}
.text-xs{font-size:var(--s6);}
.fw-bold{font-weight:700;}
.fw-semibold{font-weight:600;}
.mb-1{margin-bottom:var(--s5);}
.mb-2{margin-bottom:var(--s7);}
.mb-3{margin-bottom:var(--s9);}
.mt-1{margin-top:var(--s5);}

/* PAY CHIPS (tokenized) */
.pay-chip--today{background:var(--accent2);border-color:var(--accent2);}
.pay-chip--next{background:color-mix(in srgb,var(--accent2) 12%,transparent);border-color:color-mix(in srgb,var(--accent2) 35%,transparent);}

/* ═════════════════════════════════════════════════════════════════════════
   SETTINGS MODULE v2.0 - Phase 2
   ═════════════════════════════════════════════════════════════════════════ */

/* Settings Page Container */
.page-container{display:flex;flex-direction:column;height:100vh;background:var(--bg);}
.top-nav{display:flex;align-items:center;justify-content:center;position:relative;height:var(--nav-height);background:var(--card);border-bottom:1px solid var(--border);padding:0 var(--s9);box-shadow:0 2px 12px #0005;}
.top-nav-title{font-size:var(--s10);font-weight:700;letter-spacing:var(--tracking-sm);}
.back-btn{position:absolute;left:var(--s9);background:none;border:none;color:var(--text);font-size:1.3rem;cursor:pointer;padding:var(--s3);display:flex;align-items:center;justify-content:center;border-radius:var(--radius-sm);transition:background .15s;}
.back-btn:hover{background:var(--surface);}
.content-wrapper{flex:1;overflow-y:auto;padding:var(--s9);padding-bottom:calc(var(--s12) + var(--nav-height) + env(safe-area-inset-bottom,0px));}

/* Settings Home - Category Grid */
.settings-home{width:100%;max-width:500px;margin:0 auto;}
.settings-grid{display:grid;grid-template-columns:1fr;gap:var(--s9);}

/* Settings Category Card */
.settings-card{background:var(--card);border:1px solid var(--border);border-radius:var(--radius-lg);padding:var(--s7) var(--s9);cursor:pointer;transition:transform .15s,box-shadow .15s;position:relative;display:flex;flex-direction:row;gap:var(--s9);min-height:68px;-webkit-tap-highlight-color:transparent;align-items:center;}
.settings-card:active{transform:scale(.97);}
.settings-card:hover{box-shadow:0 4px 16px #0004;}
.settings-card-icon{display:flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:var(--radius-sm);background:var(--surface);color:var(--accent2);}
.settings-card-icon svg{width:var(--icon-lg);height:var(--icon-lg);stroke:currentColor;fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round;}
.settings-card-content{flex:1;display:flex;flex-direction:column;gap:var(--s3);}
.settings-card-title{font-weight:700;font-size:var(--s9);color:var(--text);}
.settings-card-desc{font-size:var(--s6);color:var(--muted);line-height:1.3;margin-top:var(--s2);}
.settings-card-arrow{position:absolute;top:50%;right:var(--s8);transform:translateY(-50%);color:var(--muted);font-size:var(--s11);font-weight:300;}

/* Settings Section Pages */
.settings-section{max-width:600px;margin:0 auto;}
.settings-section h3{font-size:var(--s11);font-weight:700;margin-bottom:var(--s9);color:var(--text);}
.settings-section-desc{font-size:var(--s8);color:var(--muted);margin-bottom:var(--s10);line-height:1.5;}

/* Settings Groups */
.settings-group{margin-bottom:var(--s12);}
.settings-group-title{font-size:var(--s9);font-weight:700;color:var(--text);margin-bottom:var(--s8);padding-bottom:var(--s5);border-bottom:1px solid var(--border);}
.settings-group-body{background:var(--card);border:1px solid var(--border);border-radius:var(--radius-md);padding:var(--s8) var(--s9);}


/* Themes Grid */
.themes-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--s9);}
@media(min-width:320px){.themes-grid{grid-template-columns:repeat(3,1fr);}}
.theme-card{background:var(--surface);border:2px solid var(--border);border-radius:var(--radius-md);padding:var(--s8);cursor:pointer;transition:transform .15s,border-color .15s;position:relative;}
.theme-card:hover{border-color:var(--accent2);transform:scale(1.02);}
.theme-card-active{border-color:var(--accent2);background:color-mix(in srgb,var(--accent2) 10%,var(--surface));}
.theme-card-preview{width:100%;aspect-ratio:3/2;background:linear-gradient(135deg,var(--bg),var(--card));border-radius:var(--radius-sm);margin-bottom:var(--s6);position:relative;overflow:hidden;}
.theme-card-checkmark{position:absolute;top:var(--s4);right:var(--s4);background:var(--accent2);color:#000;width:24px;height:24px;border-radius:var(--radius-circle);display:flex;align-items:center;justify-content:center;font-size:.8rem;font-weight:700;}
.theme-card-name{font-size:var(--s8);font-weight:600;text-align:center;color:var(--text);}

/* ═══ DASHBOARD WIDGET GRID ═══ */
.widget-grid{display:grid;grid-template-columns:1fr;gap:var(--s9);padding:var(--s9);padding-bottom:calc(var(--s12) + var(--nav-height) + env(safe-area-inset-bottom,0px));max-width:var(--content-max-w);margin:0 auto;}
@media(min-width:480px){.widget-grid{grid-template-columns:repeat(2,1fr);}}

/* Widget Slot */
.widget-slot{background:var(--card);border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden;transition:opacity .2s,transform .15s;position:relative;min-height:120px;display:flex;flex-direction:column;}
.widget-slot-dragging{opacity:.5;transform:scale(.98);}
.widget-slot-dragover{border-color:var(--accent2);box-shadow:0 0 0 2px color-mix(in srgb,var(--accent2) 20%,transparent);}

/* Widget Slot Header */
.widget-slot-header{display:flex;align-items:center;justify-content:space-between;padding:var(--s6) var(--s8);border-bottom:1px solid var(--border);background:var(--surface);cursor:grab;user-select:none;}
.widget-slot-header:active{cursor:grabbing;}
.widget-slot-title{display:flex;align-items:center;gap:var(--s5);font-size:var(--s8);font-weight:700;color:var(--text);}
.widget-slot-icon{font-size:var(--s10);line-height:1;}
.widget-slot-actions{display:flex;align-items:center;gap:var(--s4);}
.widget-slot-btn{background:none;border:none;cursor:pointer;color:var(--muted);padding:var(--s2);display:flex;align-items:center;justify-content:center;border-radius:var(--radius-sm);transition:background .15s,color .15s;}
.widget-slot-btn:hover{background:var(--card);color:var(--text);}
.widget-slot-btn svg{width:var(--icon-sm);height:var(--icon-sm);stroke:currentColor;fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round;}

/* Widget Slot Content */
.widget-slot-content{flex:1;padding:var(--s8);position:relative;display:flex;flex-direction:column;}

/* Widget Sizes */
.widget-slot-compact{min-height:100px;}
.widget-slot-compact .widget-slot-content{padding:var(--s6);}
.widget-slot-standard{min-height:140px;}
.widget-slot-expanded{min-height:200px;grid-column:span 1;}
@media(min-width:480px){.widget-slot-expanded{grid-column:span 2;}}

/* Widget Loading State */
.widget-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--s12);color:var(--muted);gap:var(--s6);}
.widget-spinner{width:28px;height:28px;border:3px solid var(--border);border-top-color:var(--accent2);border-radius:var(--radius-circle);animation:widget-spin 1s linear infinite;}
@keyframes widget-spin{to{transform:rotate(360deg);}}
.widget-loading-text{font-size:var(--s7);color:var(--muted);}

/* Widget Error State */
.widget-error{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--s9);text-align:center;color:var(--danger);gap:var(--s5);}
.widget-error-icon{font-size:var(--s12);line-height:1;}
.widget-error-text{font-size:var(--s7);line-height:1.4;}
.widget-error-retry{margin-top:var(--s4);}

/* ═══ APP STORE ═══ */
.as-search-row{display:flex;gap:var(--s7);align-items:center;margin-bottom:var(--s9);}
.as-search{flex:1;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-pill);padding:var(--s7) var(--s9);color:var(--text);font-size:.82rem;outline:none;-webkit-appearance:none;}
.as-search:focus{border-color:var(--accent2);}
.as-cats{display:flex;gap:var(--s5);overflow-x:auto;padding-bottom:var(--s5);scrollbar-width:none;margin-bottom:var(--s9);}
.as-cats::-webkit-scrollbar{display:none;}
.as-cat-pill{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-pill);padding:var(--s4) var(--s9);font-size:.74rem;color:var(--muted);cursor:pointer;white-space:nowrap;transition:background .15s,color .15s;-webkit-tap-highlight-color:transparent;}
.as-cat-pill.active{background:var(--accent2);border-color:var(--accent2);color:#000;font-weight:700;}
.as-grid{display:grid;grid-template-columns:1fr 1fr;gap:var(--s9);}
.as-card{background:var(--card);border:1px solid var(--border);border-radius:var(--radius-lg);padding:var(--s9);display:flex;flex-direction:column;gap:var(--s6);cursor:pointer;transition:transform .12s;-webkit-tap-highlight-color:transparent;}
.as-card:active{transform:scale(.97);}
.as-card-icon{width:52px;height:52px;border-radius:var(--radius-md);background:var(--surface);display:flex;align-items:center;justify-content:center;font-size:1.6rem;border:1px solid var(--border);}
.as-card-name{font-weight:700;font-size:.82rem;color:var(--text);}
.as-card-desc{font-size:.68rem;color:var(--muted);line-height:1.4;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;}
.as-card-footer{margin-top:auto;}
.as-add-btn{width:100%;padding:var(--s5) 0;border-radius:var(--radius-pill);font-size:.72rem;font-weight:700;border:none;cursor:pointer;transition:opacity .15s;}
.as-add-btn.add{background:var(--accent2);color:#000;}
.as-add-btn.remove{background:var(--surface);border:1px solid var(--border);color:var(--muted);}
.as-add-btn.required{background:var(--surface);border:1px solid var(--border);color:var(--muted);cursor:not-allowed;opacity:.6;}
.as-add-btn:active{opacity:.75;}
/* Detail page */
.as-detail-hero{display:flex;flex-direction:column;align-items:center;gap:var(--s7);padding:var(--s11) 0 var(--s10);}
.as-detail-icon{width:72px;height:72px;border-radius:var(--radius-lg);background:var(--surface);display:flex;align-items:center;justify-content:center;font-size:2.2rem;border:1px solid var(--border);}
.as-detail-name{font-size:1.1rem;font-weight:700;color:var(--text);text-align:center;}
.as-detail-badge{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-pill);padding:var(--s3) var(--s8);font-size:.68rem;color:var(--muted);}
.as-detail-action{width:100%;max-width:220px;padding:var(--s7) 0;border-radius:var(--radius-pill);font-size:.85rem;font-weight:700;border:none;cursor:pointer;transition:opacity .15s;}
.as-detail-action.add{background:var(--accent2);color:#000;}
.as-detail-action.remove{background:var(--surface);border:1px solid var(--border);color:var(--muted);}
.as-detail-action.required{background:var(--surface);border:1px solid var(--border);color:var(--muted);cursor:not-allowed;opacity:.6;}
.as-detail-action:active{opacity:.75;}
.as-info-chips{display:flex;gap:var(--s7);justify-content:center;flex-wrap:wrap;margin-bottom:var(--s10);}
.as-chip{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-sm);padding:var(--s5) var(--s9);text-align:center;min-width:70px;}
.as-chip-label{font-size:.62rem;color:var(--muted);display:block;}
.as-chip-value{font-size:.8rem;font-weight:700;color:var(--text);display:block;margin-top:var(--s1);}
.as-section-title{font-weight:700;font-size:.85rem;color:var(--text);margin-bottom:var(--s7);padding-bottom:var(--s5);border-bottom:1px solid var(--border);}
.as-section-body{font-size:.8rem;color:var(--muted);line-height:1.6;}
.as-detail-row{display:flex;justify-content:space-between;align-items:center;padding:var(--s6) 0;border-bottom:1px solid var(--border);}
.as-detail-row:last-child{border-bottom:none;}
.as-detail-row-label{color:var(--muted);font-size:.78rem;}
.as-detail-row-value{color:var(--text);font-weight:600;font-size:.78rem;}
/* App Store — type badge on cards */
.as-card-type{font-size:.62rem;color:var(--muted);background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-pill);padding:.1rem .45rem;display:inline-block;line-height:1.5;}
/* App Store — carousel */
.as-carousel{overflow:hidden;border-radius:var(--radius-lg);margin-bottom:var(--s9);position:relative;}
.as-carousel-track{display:flex;transition:transform .4s ease;will-change:transform;}
.as-carousel-slide{min-width:100%;height:130px;background:var(--card);border:1px solid var(--border);border-radius:var(--radius-lg);display:flex;align-items:center;gap:var(--s10);padding:var(--s10) var(--s11);box-sizing:border-box;-webkit-tap-highlight-color:transparent;}
.as-carousel-slide:active{opacity:.85;}
.as-carousel-slide-icon{font-size:2.8rem;flex-shrink:0;line-height:1;}
.as-carousel-slide-body{flex:1;min-width:0;}
.as-carousel-slide-badge{font-size:.6rem;color:var(--muted);background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-pill);padding:.1rem .4rem;display:inline-block;margin-bottom:.3rem;line-height:1.5;}
.as-carousel-slide-name{font-size:.95rem;font-weight:700;color:var(--text);margin-bottom:.2rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.as-carousel-slide-tag{font-size:.7rem;color:var(--muted);line-height:1.35;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;}
.as-carousel-dots{display:flex;justify-content:center;gap:var(--s5);margin-top:var(--s6);}
.as-carousel-dot{width:6px;height:6px;border-radius:50%;background:var(--border);transition:background .2s;cursor:pointer;}
.as-carousel-dot.active{background:var(--accent2);}
/* Accessibility body classes */
.a11y-large-text{font-size:110%;}
.a11y-reduce-motion *{transition:none!important;animation:none!important;}
.a11y-high-contrast{filter:contrast(1.15);}
