  /* ============================================================
     CARDS
  ============================================================ */
  .card{background:var(--bg-card);border:1px solid var(--line-color);border-radius:8px;padding:16px;
    margin-bottom:26px;position:relative;overflow:hidden;
    transition:background 0.25s,border-color 0.25s,transform 0.15s;cursor:pointer;
    box-shadow:var(--shadow);}
  .card:hover{background:var(--card-hover-bg);}
  .card:active{transform:scale(0.992);}
  .card-label{font-size:.6rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase;
    color:var(--text-muted);margin-bottom:10px;}

  /* ============================================================
     TAGS
  ============================================================ */
  .tag{font-family:'Inter',sans-serif;font-size:.6rem;font-weight:600;letter-spacing:.04em;
    text-transform:uppercase;color:var(--accent);background:rgba(16,185,129,0.1);
    border:1px solid rgba(16,185,129,0.25);border-radius:4px;padding:2px 8px;white-space:nowrap;flex-shrink:0;}
  .tag-muted {color:var(--text-muted);background:transparent;border-color:var(--line-color);}
  .tag-urgent{color:#ef4444;background:rgba(239,68,68,0.1);border-color:rgba(239,68,68,0.3);}
  .tag-soon  {color:#f59e0b;background:rgba(245,158,11,0.1);border-color:rgba(245,158,11,0.3);}
  .tag-action{color:#60a5fa;background:rgba(96,165,250,0.1);border-color:rgba(96,165,250,0.3);}
  .tag-health{color:#10b981;background:rgba(16,185,129,0.1);border-color:rgba(16,185,129,0.3);}
  .tag-med   {color:#60a5fa;background:rgba(96,165,250,0.12);border-color:rgba(96,165,250,0.35);font-weight:700;}
  .tag-recipe{color:#10b981;background:rgba(16,185,129,0.12);border-color:rgba(16,185,129,0.4);font-weight:700;}
  .tag-family{color:#a78bfa;background:rgba(167,139,250,0.1);border-color:rgba(167,139,250,0.3);}
  /* Paid pill (2026-05-30): green-on-green tinted so it reads as "settled, no
     action needed." Distinct from .tag-recipe (also green) by being lighter
     weight and adding a leading ✓ via ::before. */
  .tag-paid{color:#0f766e;background:rgba(16,185,129,0.14);border-color:rgba(16,185,129,0.35);font-weight:700;}
  .tag-paid::before{content:"✓ ";font-weight:800;}

  /* ============================================================
     BUTTONS
  ============================================================ */
  .btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;font-family:'Inter',sans-serif;
    font-size:var(--fs-base);font-weight:500;letter-spacing:-0.01em;cursor:pointer;
    transition:all 0.15s;border:1px solid transparent;border-radius:4px;white-space:nowrap;}
  .btn:active{transform:scale(0.98);}
  .btn-primary{background:var(--accent);color:#000;border-color:var(--accent);padding:12px 32px;width:100%;
    box-shadow:0 2px 8px rgba(16,185,129,0.25);}
  .btn-primary:hover{background:var(--accent-hover);border-color:var(--accent-hover);}
  .btn-ghost{background:transparent;color:var(--text-secondary);border-color:var(--line-color);}
  .btn-ghost:hover{border-color:var(--accent);color:var(--accent);}

  /* ============================================================
     DASHBOARD — STREAK
  ============================================================ */
  .streak-card{background:linear-gradient(135deg,#10b981 0%,#059669 100%);color:#fff;
    border-color:transparent;box-shadow:0 4px 18px rgba(16,185,129,0.3);padding:20px 18px 16px;}
  .streak-card .card-label{color:rgba(255,255,255,0.7);}
  .streak-glow{position:absolute;top:-30px;right:-30px;width:120px;height:120px;
    background:radial-gradient(circle,rgba(255,255,255,0.15) 0%,transparent 70%);pointer-events:none;}
  .streak-num{font-family:'Inter',sans-serif;font-size:clamp(3rem,10vw,4.2rem);font-weight:800;
    line-height:1;color:#fff;letter-spacing:-0.04em;}
  .streak-label{font-size:var(--fs-md);font-weight:500;color:rgba(255,255,255,0.9);margin-bottom:3px;}
  .streak-sub{font-size:var(--fs-xs);color:rgba(255,255,255,0.7);margin-top:8px;font-weight:500;}

  /* ============================================================
     METRICS GRID
  ============================================================ */
  .metrics-row{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:56px;}
  .metric-card{background:var(--bg-card);border:1px solid var(--line-color);border-radius:8px;
    padding:14px 14px 12px;position:relative;overflow:hidden;
    transition:background 0.25s,border-color 0.25s;cursor:pointer;box-shadow:var(--shadow);}
  .metric-card:hover{background:var(--card-hover-bg);border-color:rgba(16,185,129,0.3);}
  .metric-value{font-family:'Inter',sans-serif;font-size:clamp(1.6rem,5vw,2.2rem);font-weight:800;
    letter-spacing:-0.04em;line-height:1.1;color:var(--accent);}
  .metric-label{font-size:.6rem;font-weight:600;color:var(--text-muted);margin-top:3px;text-transform:uppercase;letter-spacing:.06em;}
  .metric-sub{font-size:.55rem;font-weight:400;color:var(--text-muted);margin-top:1px;opacity:.7;}
  /* Invite state — same card background as all other cards, only text colors change */
  .metric-card.metric-invite .metric-label{color:#22D3EE;}
  .metric-card.metric-invite .money-ring-amt{color:var(--text-muted);}

  /* Budget Progress Ring */
  .money-ring-svg{display:block;overflow:visible;}
  .money-ring-track{stroke:var(--ring-track);}
  .money-ring-arc{transition:stroke-dashoffset 1.5s cubic-bezier(.25,1,.5,1);}
  .money-ring-amt{font-size:.58rem;font-weight:600;color:var(--text-muted);
    margin-top:5px;letter-spacing:.01em;text-align:center;}
  /* Health 48h list — hover expands */
  .health-48-list{display:flex;flex-direction:column;gap:3px;margin-top:6px;cursor:default;}
  .h48-item{display:flex;align-items:center;gap:5px;font-size:.6rem;color:var(--text-secondary);font-weight:500;
    transition:font-size .18s,color .18s;}
  .h48-dot{width:5px;height:5px;border-radius:50%;flex-shrink:0;background:var(--accent);transition:width .18s,height .18s;}
  .metric-card:hover .h48-item{font-size:.78rem;color:var(--text-primary);}
  .metric-card:hover .h48-dot{width:7px;height:7px;}

  /* Metric card ear-tag */
  .mc-ear{position:absolute;top:0;right:0;width:20px;height:20px;cursor:pointer;
    z-index:2;border-radius:0 8px 0 8px;background:var(--line-color);
    display:flex;align-items:center;justify-content:center;
    transition:background .15s,transform .15s;overflow:hidden;}
  .mc-ear:hover{background:rgba(239,68,68,0.18);transform:scale(1.15);}
  .mc-ear svg{width:9px;height:9px;stroke:var(--text-muted);fill:none;stroke-width:2.5;stroke-linecap:round;pointer-events:none;}
  .mc-ear:hover svg{stroke:#ef4444;}
  /* Drag state for metric cards */
  /* Mode B — left arrow ear */
  .mc-left-ear{position:absolute;top:0;left:0;width:22px;height:22px;cursor:pointer;
    display:flex;align-items:center;justify-content:center;border-radius:6px 0 4px 0;
    background:rgba(16,185,129,0.07);transition:background .14s,transform .14s;}
  .mc-left-ear:hover{background:rgba(16,185,129,0.2);transform:scale(1.12);}
  .mc-left-ear svg{width:11px;height:11px;stroke:var(--accent);fill:none;stroke-width:2.5;stroke-linecap:round;stroke-linejoin:round;pointer-events:none;}
  /* Mode A — move overlay arrows */
  .mc-move-overlay{position:absolute;inset:0;display:flex;align-items:flex-end;
    justify-content:space-between;padding:5px;border-radius:8px;
    background:rgba(0,0,0,0.18);z-index:10;pointer-events:all;}
  .mc-move-arrow{width:26px;height:26px;background:rgba(0,0,0,0.52);border:none;border-radius:4px;
    color:#fff;font-size:.95rem;font-weight:700;cursor:pointer;display:flex;align-items:center;
    justify-content:center;transition:background .15s;padding:0;line-height:1;}
  .mc-move-arrow:hover:not(:disabled){background:rgba(16,185,129,0.8);}
  .mc-move-arrow:disabled{opacity:0.25;cursor:default;}

  /* Add-card strip between metrics and needs-attention */
  .add-card-strip{display:flex;align-items:center;justify-content:center;gap:8px;
    margin:-40px 0 22px;position:relative;z-index:1;}
  .add-card-btn{display:flex;align-items:center;gap:6px;padding:6px 14px 6px 10px;
    background:var(--bg-card);border:1.5px dashed var(--line-color);border-radius:20px;
    cursor:pointer;transition:all .18s;font-family:'Inter',sans-serif;}
  .add-card-btn:hover{border-color:var(--accent);background:rgba(16,185,129,0.06);}
  .add-card-btn-icon{width:18px;height:18px;border-radius:50%;background:var(--accent);
    display:flex;align-items:center;justify-content:center;flex-shrink:0;}
  .add-card-btn-icon svg{width:10px;height:10px;stroke:#fff;fill:none;stroke-width:2.5;stroke-linecap:round;}
  .add-card-btn-label{font-size:.72rem;font-weight:700;color:var(--text-muted);letter-spacing:.03em;}
  .add-card-btn:hover .add-card-btn-label{color:var(--accent);}

  /* Add-card picker modal */
  #add-card-overlay{position:fixed;inset:0;z-index:6400;background:rgba(0,0,0,0);
    pointer-events:none;transition:background .25s;display:flex;align-items:flex-end;
    left:max(0px,calc(50vw - 260px));width:min(100vw,520px);}
  #add-card-overlay.open{background:rgba(0,0,0,0.55);pointer-events:all;}
  #add-card-panel{width:100%;background:var(--bg-card);border-radius:16px 16px 0 0;
    padding:0 0 36px;transform:translateY(100%);
    transition:transform .32s cubic-bezier(.25,1,.5,1);max-height:80dvh;overflow-y:auto;
    box-shadow:0 -8px 32px rgba(0,0,0,0.18);}
  #add-card-overlay.open #add-card-panel{transform:translateY(0);}
  .acp-handle{width:36px;height:4px;background:var(--line-color);border-radius:2px;margin:12px auto 0;}
  .acp-title{font-size:1rem;font-weight:700;color:var(--text-primary);padding:14px 20px 4px;letter-spacing:-.02em;}
  .acp-sub{font-size:.78rem;color:var(--text-muted);padding:0 20px 14px;}
  .acp-card-row{display:flex;align-items:center;gap:14px;padding:12px 20px;
    border-top:1px solid var(--line-color);cursor:pointer;transition:background .14s;}
  .acp-card-row:hover{background:var(--bg-secondary);}
  .acp-card-row.disabled{opacity:.38;cursor:default;pointer-events:none;}
  .acp-icon{width:36px;height:36px;border-radius:8px;background:rgba(16,185,129,0.09);
    border:1px solid rgba(16,185,129,0.2);display:flex;align-items:center;justify-content:center;
    flex-shrink:0;}
  .acp-icon svg{width:16px;height:16px;stroke:var(--accent);fill:none;stroke-width:1.8;stroke-linecap:round;stroke-linejoin:round;}
  .acp-info{flex:1;}
  .acp-name{font-size:.88rem;font-weight:600;color:var(--text-primary);}
  .acp-desc{font-size:.72rem;color:var(--text-muted);margin-top:1px;}
  .acp-badge{font-size:.6rem;font-weight:700;padding:2px 7px;border-radius:4px;flex-shrink:0;}
  .acp-badge.active{background:rgba(16,185,129,0.12);color:var(--accent);}
  .acp-badge.add{background:rgba(16,185,129,0.9);color:#fff;}

  /* ============================================================
     URGENT ITEMS
  ============================================================ */
  .urgent-list{list-style:none;}
  .urgent-item{display:flex;align-items:flex-start;gap:12px;padding:13px 0;
    border-bottom:1px solid var(--line-color);cursor:pointer;transition:background 0.15s;
    margin:0 -20px;padding-left:20px;padding-right:20px;}
  .urgent-item:last-child{border-bottom:none;padding-bottom:0;} .urgent-item:first-child{padding-top:0;}
  .urgent-item:hover{background:rgba(var(--accent-rgb),0.04);}
  /* "Remove from focus" button — sits inline, immediately before the day-label tag */
  .focus-remove-btn{flex-shrink:0;width:28px;height:28px;align-self:center;
    display:flex;align-items:center;justify-content:center;border-radius:6px;
    background:transparent;border:1px solid transparent;color:var(--text-muted);
    cursor:pointer;opacity:0.45;transition:opacity .15s,background .15s,color .15s,border-color .15s;
    padding:0;line-height:0;margin-right:2px;}
  .urgent-item:hover .focus-remove-btn,
  .cal-event:hover .focus-remove-btn,
  .focus-remove-btn:focus-visible{opacity:1;}
  .focus-remove-btn:hover,
  .focus-remove-btn:active{background:rgba(239,68,68,0.12);border-color:rgba(239,68,68,0.40);color:#ef4444;opacity:1;}
  .urgent-dot{width:6px;height:6px;border-radius:50%;flex-shrink:0;margin-top:6px;}
  .urgent-dot.red{background:#ef4444;box-shadow:0 0 8px rgba(239,68,68,0.5);animation:pulseDot 2.2s ease-in-out infinite;}
  .urgent-dot.orange{background:#f59e0b;} .urgent-dot.blue{background:#60a5fa;} .urgent-dot.green{background:#10b981;}
  @keyframes pulseDot{0%,100%{opacity:1;transform:scale(1)}50%{opacity:.5;transform:scale(.7)}}
  .urgent-text{flex:1;min-width:0;}
  .urgent-title{font-size:var(--fs-base);font-weight:400;color:var(--text-primary);}
  .urgent-meta{font-size:var(--fs-xs);color:var(--text-muted);margin-top:2px;font-weight:300;}

  /* ============================================================
     CHART WRAPPERS
  ============================================================ */
  .chart-wrapper{height:160px;position:relative;overflow:hidden;}
  .chart-wrapper-sm{height:180px;position:relative;overflow:hidden;}

  /* ============================================================
     CHARTS HALF-ROW
  ============================================================ */
  .charts-half-row{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:28px;}
  .charts-half-card{margin:0!important;padding:14px 12px 16px!important;}
  .charts-half-card .card-label{font-size:.62rem;margin-bottom:10px;}
  .charts-half-card .chart-wrapper-sm{height:110px;}

  /* ============================================================
     PIE CHART CARD
  ============================================================ */
  .pie-half-inner{display:flex;flex-direction:column;align-items:center;}
  .pie-wrapper{height:150px;position:relative;}
  .pie-wrapper-half{height:120px;width:120px;position:relative;flex-shrink:0;}
  .pie-center-label{position:absolute;inset:0;display:flex;flex-direction:column;
    align-items:center;justify-content:center;pointer-events:none;}
  .pie-center-val{font-size:1.35rem;font-weight:700;color:var(--text-primary);line-height:1;}
  .pie-center-sub{font-size:.52rem;font-weight:600;color:var(--text-muted);
    text-transform:uppercase;letter-spacing:.05em;margin-top:3px;}
  /* keep legend classes for the detail panel */
  .pie-legend{display:flex;flex-direction:column;gap:6px;width:100%;}
  .pie-legend-item{display:flex;align-items:center;gap:6px;font-size:.62rem;color:var(--text-primary);}
  .pie-legend-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0;}
  .pie-legend-label{font-weight:500;letter-spacing:0.01em;color:var(--text-primary);flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;}
  .pie-legend-val{font-family:var(--font-display);font-size:.75rem;font-weight:600;color:var(--accent);flex-shrink:0;}

  /* ============================================================
     HEATMAP
  ============================================================ */
  .heatmap-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:10px;}
  .heatmap-day-labels{display:grid;grid-template-rows:repeat(7,10px);gap:3px;margin-right:6px;flex-shrink:0;}
  .hm-day-label{font-size:8px;font-weight:400;color:var(--text-muted);letter-spacing:.05em;
    text-transform:uppercase;height:10px;display:flex;align-items:center;}
  .heatmap-scroll{overflow-x:auto;padding-bottom:2px;}
  .heatmap-scroll::-webkit-scrollbar{height:2px;} .heatmap-scroll::-webkit-scrollbar-thumb{background:var(--line-strong);}
  .heatmap-outer{display:flex;align-items:flex-start;gap:0;}
  .heatmap-grid{display:grid;grid-template-rows:repeat(7,10px);grid-auto-columns:10px;
    grid-auto-flow:column;gap:3px;min-width:max-content;}
  .hm-cell{width:10px;height:10px;border-radius:1px;transition:transform 0.15s;}
  .hm-cell:hover{transform:scale(1.4);cursor:default;}
  .hm-cell.hm-0{background:var(--hm-0);}
  .hm-cell.hm-1{background:var(--hm-1);}
  .hm-cell.hm-2{background:var(--hm-2);}
  .hm-cell.hm-3{background:var(--hm-3);}
  .hm-cell.hm-4{background:var(--hm-4);}
  .heatmap-legend{display:flex;align-items:center;gap:4px;margin-top:8px;}
  .hm-legend-label{font-size:.58rem;color:var(--text-muted);letter-spacing:.05em;}
  .hm-legend-cells{display:flex;gap:3px;}

  /* ============================================================
     INSPECT
  ============================================================ */
  .drop-zone{border:2px dashed var(--line-color);border-radius:8px;padding:28px 20px;text-align:center;
    cursor:pointer;background:var(--bg-secondary);transition:all 0.15s;margin-bottom:12px;}
  .drop-zone:hover,.drop-zone.dragover{border-color:var(--accent);background:rgba(16,185,129,0.05);}
  .drop-icon{margin-bottom:10px;display:flex;justify-content:center;}
  .drop-title{font-family:'Inter',sans-serif;font-size:var(--fs-md);font-weight:700;letter-spacing:-0.02em;
    color:var(--text-primary);margin-bottom:4px;}
  .drop-sub{font-size:var(--fs-sm);color:var(--text-muted);}
  .paste-area{width:100%;min-height:110px;background:var(--form-input-bg);border:1px solid var(--line-color);
    border-radius:8px;padding:13px;font-family:'Inter',sans-serif;font-size:var(--fs-base);font-weight:400;
    color:var(--text-primary);resize:vertical;outline:none;margin-bottom:10px;
    transition:border-color 0.15s,background 0.25s;line-height:1.6;}
  .paste-area::placeholder{color:var(--text-muted);}
  .paste-area:focus{border-color:var(--accent);box-shadow:0 0 0 3px rgba(16,185,129,0.12);}
  /* ── Inspect section label — readable on any bg photo ── */
  .inspect-section-label{display:inline-flex;align-items:center;gap:6px;
    font-size:.72rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:#fff;
    background:rgba(10,18,28,0.80);border:1px solid rgba(16,185,129,0.5);border-radius:4px;
    padding:4px 10px;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);margin-bottom:10px;}
  .inspect-section-label-dot{width:6px;height:6px;border-radius:50%;background:var(--accent);flex-shrink:0;}
  /* Phase 7 — scoped My Files section toggle: ~2.5x taller, clearly a tappable
     button (not just a label). Does NOT alter the shared .inspect-section-label
     used elsewhere (Coming Up, Recommendations, etc.). */
  .mf-section-toggle{display:flex;width:100%;box-sizing:border-box;min-height:52px;
    padding:15px 14px;font-size:.82rem;border-radius:6px;
    background:rgba(10,18,28,0.85);border:1px solid rgba(16,185,129,0.45);
    transition:background .15s,border-color .15s,transform .08s;}
  .mf-section-toggle:hover{background:rgba(16,185,129,0.14);border-color:rgba(16,185,129,0.7);}
  .mf-section-toggle:active{transform:scale(0.992);background:rgba(16,185,129,0.20);}
  .mf-section-toggle .mf-count{margin-left:8px;font-size:.7rem;font-weight:600;
    color:var(--text-muted,#94a3b8);letter-spacing:0;text-transform:none;}
  /* ── 2-column file grid ── */
  .inspect-items{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-top:0;}
  /* ── Multi-page document collector strip ── */
  /* multi-page modal */
  #mpModal{position:fixed;inset:0;z-index:9200;background:rgba(13,27,42,.7);display:none;align-items:flex-end;justify-content:center;backdrop-filter:blur(3px);-webkit-backdrop-filter:blur(3px);}
  #mpModal.open{display:flex;}
  .mp-modal-card{background:var(--bg-card);border-radius:16px 16px 0 0;padding:6px 20px 36px;width:100%;max-width:480px;min-height:80vh;max-height:92vh;overflow-y:auto;transform:translateY(100%);transition:transform .3s cubic-bezier(.34,1.06,.64,1);}
  #mpModal.open .mp-modal-card{transform:translateY(0);}
  .mp-modal-drag{width:36px;height:4px;background:var(--line-color);border-radius:2px;margin:10px auto 18px;}
  .mp-modal-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:6px;}
  .mp-modal-title{font-size:1rem;font-weight:700;color:var(--text-primary);letter-spacing:-.01em;}
  .mp-modal-title.mp-med{color:#60A5FA;}
  .mp-modal-close{background:none;border:none;padding:6px;cursor:pointer;color:var(--text-muted);line-height:0;border-radius:4px;margin-right:-6px;}
  .mp-modal-sub{font-size:.82rem;color:var(--text-secondary);margin:0 0 8px;line-height:1.45;}
  .mp-med-toggle{background:transparent;border:none;color:#60A5FA;font-size:.74rem;font-weight:600;padding:2px 0 12px;cursor:pointer;text-align:left;display:block;letter-spacing:-.01em;}
  .mp-med-toggle:active{opacity:.7;}
  .mp-thumbs{display:flex;gap:8px;overflow-x:auto;padding-bottom:4px;margin-bottom:16px;scrollbar-width:none;}
  .mp-thumbs::-webkit-scrollbar{display:none;}
  .mp-thumb{position:relative;flex-shrink:0;width:208px;height:208px;border-radius:8px;overflow:hidden;border:1.5px solid var(--line-color);background:var(--bg-secondary);}
  .mp-thumb img{width:100%;height:100%;object-fit:cover;display:block;}
  .mp-thumb-num{position:absolute;bottom:7px;left:9px;font-size:.85rem;font-weight:800;color:#fff;text-shadow:0 1px 3px rgba(0,0,0,.7);}
  .mp-thumb-del{position:absolute;top:7px;right:7px;width:28px;height:28px;background:rgba(0,0,0,.55);border:none;border-radius:50%;color:#fff;cursor:pointer;padding:0;display:flex;align-items:center;justify-content:center;}
  .mp-thumb-placeholder{display:flex;align-items:center;justify-content:center;color:var(--text-muted);}
  .mp-modal-btns{display:flex;flex-direction:column;gap:10px;}
  .mp-modal-analyze{background:var(--accent);color:#fff;border:none;border-radius:8px;padding:14px;font-size:.95rem;font-weight:700;cursor:pointer;width:100%;letter-spacing:.01em;}
  .mp-modal-analyze:active{opacity:.85;}
  .mp-modal-quick{background:#60A5FA;color:#fff;border:none;border-radius:8px;padding:14px;font-size:.95rem;font-weight:700;cursor:pointer;width:100%;letter-spacing:.01em;}
  .mp-modal-quick:active{opacity:.85;}
  .mp-modal-add{background:transparent;color:var(--accent);border:1.5px solid var(--accent);border-radius:8px;padding:13px;font-size:.95rem;font-weight:700;cursor:pointer;width:100%;}
  .mp-modal-add.pulsing{animation:mpAddPulse 1.6s ease infinite;}
  @keyframes mpAddPulse{0%,100%{box-shadow:0 0 0 0 rgba(96,165,250,.5);}60%{box-shadow:0 0 0 8px rgba(96,165,250,0);}}
  /* ── Add Info button + collapsible note panel (purple = tertiary/optional action) ── */
  .mp-modal-info{background:transparent;color:#B088CC;border:1.5px solid #B088CC;border-radius:8px;padding:13px;font-size:.95rem;font-weight:700;cursor:pointer;width:100%;font-family:'Inter',sans-serif;letter-spacing:.01em;display:flex;align-items:center;justify-content:center;gap:6px;transition:background .15s,color .15s;}
  .mp-modal-info:active{opacity:.85;}
  .mp-modal-info.open{background:#B088CC;color:#fff;}
  .mp-modal-info.has-note{border-color:#B088CC;background:rgba(176,136,204,.10);color:#7c5fa0;}
  .mp-modal-info.has-note::before{content:"✓ ";font-weight:800;}
  .mp-info-panel{display:block;background:rgba(176,136,204,.06);border:1px solid rgba(176,136,204,.30);border-radius:8px;padding:12px 12px 10px;margin-top:-2px;}
  .mp-info-panel[hidden]{display:none;}
  .mp-info-label{display:block;font-size:.74rem;font-weight:600;color:var(--text-secondary);letter-spacing:-.005em;margin-bottom:6px;line-height:1.35;}
  .mp-info-textarea{width:100%;box-sizing:border-box;border:1.5px solid var(--line-color);border-radius:6px;padding:10px 11px;font-size:.88rem;font-family:'Inter',sans-serif;color:var(--text-primary);background:var(--bg-secondary);outline:none;resize:vertical;min-height:64px;line-height:1.45;transition:border-color .15s;}
  .mp-info-textarea:focus{border-color:#B088CC;}
  .mp-info-textarea::placeholder{color:var(--text-muted);opacity:.85;}
  .mp-info-meta{display:flex;justify-content:flex-end;font-size:.66rem;color:var(--text-muted);margin-top:5px;letter-spacing:.02em;}
  /* page count badge on My Files cards */
  .mp-page-badge{font-size:.62rem;font-weight:700;color:var(--accent);background:rgba(16,185,129,.1);border:1px solid rgba(16,185,129,.25);border-radius:4px;padding:1px 5px;margin-left:4px;white-space:nowrap;}
  /* dosage highlight block in review panel */
  .dosage-block{background:linear-gradient(135deg,rgba(16,185,129,.07) 0%,rgba(96,165,250,.05) 100%);
    border:1.5px solid rgba(16,185,129,.35);border-radius:8px;padding:14px 16px;margin-bottom:14px;}
  .dosage-block-label{font-size:.68rem;font-weight:800;color:var(--accent);text-transform:uppercase;
    letter-spacing:.09em;margin-bottom:10px;display:flex;align-items:center;gap:5px;}
  .dosage-item{font-size:1.05rem;font-weight:800;color:var(--text-primary);line-height:1.55;
    padding:5px 0;border-bottom:1px solid rgba(16,185,129,.15);}
  .dosage-item:last-child{border-bottom:none;padding-bottom:0;}
  .file-bin{margin-top:6px;}
  /* The bins render directly over the #bg-layer gradient (navy→teal→mint),
     not a flat themed surface — and that backdrop can be swapped for a custom
     one. So contrast must be SELF-CONTAINED, not dependent on theme text vars
     or on what's behind it. Give the header its own navy "glass" plate +
     white text w/ shadow; make the count chip OPAQUE (the prior 0.16-alpha
     accent chip let the teal-green gradient bleed through → green-on-green). */
  .file-bin-hdr{display:flex;align-items:center;gap:8px;width:100%;border:1px solid rgba(255,255,255,0.10);
    background:rgba(13,27,42,0.55);backdrop-filter:blur(2px);-webkit-backdrop-filter:blur(2px);
    cursor:pointer;padding:8px 10px;border-radius:6px;font-family:'Inter',sans-serif;font-size:.72rem;
    font-weight:700;letter-spacing:-0.01em;color:#fff;text-shadow:0 1px 2px rgba(0,0,0,0.5);
    text-transform:uppercase;}
  .file-bin-hdr .file-bin-chevron{transition:transform .15s;flex-shrink:0;color:rgba(255,255,255,0.8);}
  .file-bin-hdr.collapsed .file-bin-chevron{transform:rotate(-90deg);}
  .file-bin-count{margin-left:auto;background:var(--accent);color:#06281d;
    border:1px solid rgba(255,255,255,0.25);text-shadow:none;
    border-radius:4px;padding:1px 7px;font-size:.68rem;font-weight:700;}
  .file-bin-body{display:flex;flex-direction:column;gap:8px;}
  .inspect-item{display:flex;flex-direction:column;gap:4px;background:var(--bg-card);
    border:1px solid var(--line-color);border-radius:8px;padding:10px 10px 9px;
    transition:background 0.15s,border-color 0.15s;cursor:pointer;box-shadow:var(--shadow);
    min-width:0;overflow:hidden;position:relative;}
  /* Phase 7 post-test: bigger & more obvious for the 50+ audience; sits well
     clear of the file/cloud icon so it can't be mis-tapped. */
  .inspect-dismiss{position:absolute;top:6px;right:6px;width:34px;height:34px;
    border:1px solid rgba(148,163,184,.30);background:rgba(148,163,184,.10);border-radius:8px;color:var(--text-muted);
    cursor:pointer;display:flex;align-items:center;justify-content:center;
    opacity:.85;transition:opacity .15s,background .15s,border-color .15s;z-index:1;padding:0;touch-action:manipulation;}
  .inspect-dismiss:hover,.inspect-dismiss:active{opacity:1;background:rgba(239,68,68,.16);border-color:rgba(239,68,68,.45);color:#ef4444;}
  .inspect-dismiss svg{width:18px;height:18px;stroke:currentColor;fill:none;stroke-width:2.6;stroke-linecap:round;}
  /* Sprint 1.3 pin star — placed at the OPPOSITE corner from dismiss so the two
     can never be mis-tapped, even for a target population with reduced motor
     control. Same 34x34 tap target, matched border weight, but a distinct
     amber/gold accent when active so the affordance is unambiguous. */
  .inspect-pin{position:absolute;bottom:6px;right:6px;width:34px;height:34px;
    border:1px solid rgba(148,163,184,.30);background:rgba(148,163,184,.10);border-radius:8px;color:#94a3b8;
    cursor:pointer;display:flex;align-items:center;justify-content:center;
    opacity:.85;transition:opacity .15s,background .15s,border-color .15s,color .15s;z-index:1;padding:0;touch-action:manipulation;}
  .inspect-pin:hover,.inspect-pin:active{opacity:1;background:rgba(245,158,11,.16);border-color:rgba(245,158,11,.45);color:#F59E0B;}
  .inspect-pin.is-pinned{background:rgba(245,158,11,.16);border-color:rgba(245,158,11,.55);color:#F59E0B;opacity:1;}
  .inspect-pin svg{width:18px;height:18px;stroke:currentColor;stroke-width:2;stroke-linecap:round;stroke-linejoin:round;}
  .inspect-pin.is-pinned svg{fill:#F59E0B;}
  .inspect-pin:not(.is-pinned) svg{fill:none;}
  /* Paid contract (2026-05-30) — "Mark Paid" button. Lives inline next to the
     tag pill (not in a corner) so it reads as a row-level action, not a meta
     toggle. Green outlined to telegraph the affirmative ("yes, settle this");
     swaps to filled-green + "Paid ✓" on tap. Hidden via inline style on
     already-paid rows (we render only when _looksLikeBill returns true). */
  .inspect-paid-btn{font-family:'Inter',sans-serif;font-size:.66rem;font-weight:700;
    letter-spacing:.04em;text-transform:uppercase;color:#10b981;
    background:rgba(16,185,129,0.06);border:1.5px solid rgba(16,185,129,0.45);
    border-radius:6px;padding:5px 10px;cursor:pointer;
    transition:background .15s,color .15s,border-color .15s;flex-shrink:0;
    touch-action:manipulation;line-height:1.1;white-space:nowrap;
    /* Keep content-sized in the column-flex card so it (a) doesn't stretch to
       full width like an inline-block <button> would by default under
       align-items:stretch, and (b) doesn't run under the bottom-right pin
       star. align-self:flex-start anchors the button to the LEFT edge; the
       44px right margin reserves clearance for the 34px pin + its 6px inset
       in case a future bill row needs the paid+tag pair to occupy the same
       row. */
    align-self:flex-start;margin-right:44px;}
  .inspect-paid-btn:hover,.inspect-paid-btn:active{background:rgba(16,185,129,0.16);border-color:rgba(16,185,129,0.65);}
  .inspect-paid-btn:disabled,.inspect-paid-btn.is-paid{background:#10b981;color:#fff;border-color:#10b981;cursor:default;}
  /* Mark Unpaid reverse lever (2026-05-31): amber-tinted so it reads as a
     corrective/undo action distinct from the affirmative green "Mark Paid".
     Sits on an already-dimmed .is-paid card so opacity is inherited; the amber
     outline still telegraphs that the button is a different state. */
  .inspect-paid-btn.is-unpaid-toggle{color:#B45309;background:rgba(245,158,11,0.06);border-color:rgba(245,158,11,0.45);}
  .inspect-paid-btn.is-unpaid-toggle:hover,
  .inspect-paid-btn.is-unpaid-toggle:active{background:rgba(245,158,11,0.16);border-color:rgba(245,158,11,0.65);}
  /* Already-paid row: dim the whole card so the eye skips it when scanning
     for bills due, but keep it visible/readable (history isn't hidden). */
  .inspect-item.is-paid{opacity:.62;}
  .inspect-item.is-paid:hover{opacity:.82;}
  .inspect-item:hover{background:var(--card-hover-bg);border-color:rgba(16,185,129,0.3);}
  .inspect-icon{width:28px;height:28px;display:flex;align-items:center;justify-content:center;
    border:1px solid var(--line-color);border-radius:6px;flex-shrink:0;
    color:var(--accent);background:rgba(16,185,129,0.06);margin-bottom:4px;}
  .inspect-icon svg{width:14px;height:14px;}
  .inspect-info{min-width:0;}
  .inspect-name{font-size:.75rem;font-weight:500;color:var(--text-primary);
    display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;
    overflow:hidden;word-break:break-all;line-height:1.35;}
  .inspect-name-wrap{display:flex;align-items:flex-start;gap:3px;}
  .inspect-name-wrap .inspect-name{flex:1;min-width:0;}
  .edit-pencil{flex-shrink:0;background:none;border:none;padding:0 1px;cursor:pointer;
    color:var(--text-muted);opacity:0.45;line-height:1;margin-top:1px;touch-action:manipulation;}
  .edit-pencil:hover,.edit-pencil:active{opacity:1;color:var(--accent);}
  .edit-pencil svg{width:9px;height:9px;stroke:currentColor;fill:none;stroke-width:2;
    stroke-linecap:round;stroke-linejoin:round;}
  .inspect-name[contenteditable="true"]{
    display:block;-webkit-line-clamp:unset;outline:none;
    border-bottom:1px dashed var(--accent);padding-bottom:1px;
    cursor:text;}
  .inspect-name[contenteditable="true"]:focus{border-bottom-style:solid;}
  .inspect-meta{font-size:.67rem;color:var(--text-muted);margin-top:3px;font-weight:300;
    display:flex;align-items:center;gap:4px;flex-wrap:wrap;}
  .inspect-item .tag{margin-top:5px;align-self:flex-start;font-size:.62rem;padding:1px 6px;}

  /* ── Compact Bento Library ───────────────────────────────── */
  .bento-library{margin-top:24px;padding-bottom:8px;}
  .bento-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;margin-top:10px;}

  /* Tile base — dark glass + color tint so tiles are always legible */
  .bento-tile{border-radius:12px;border:1.5px solid var(--bt-border);
    background:linear-gradient(148deg, var(--bt-tint) 0%, var(--bt-base) 100%);
    backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);
    padding:10px 10px 9px;cursor:pointer;
    display:flex;flex-direction:column;overflow:hidden;position:relative;
    transition:transform .15s,border-color .18s;}
  .bento-tile:active{transform:scale(.968);}
  .bento-tile:hover{border-color:var(--bt-bg);}

  /* grid spans */
  .bt-photos{grid-column:span 2;min-height:108px;}
  .bt-files {grid-column:span 1;min-height:108px;}
  .bt-audio {grid-column:span 1;min-height:88px;}
  .bt-links {grid-column:span 1;min-height:88px;}
  .bt-video {grid-column:span 1;min-height:88px;}
  .bt-notes {grid-column:span 3;min-height:72px;}
  .bt-email {grid-column:span 3;min-height:72px;}

  /* per-category color tokens */
  /* Border colors mirror the tag palette from the Recent Files cards above */
  .bt-photos{--bt-border:rgba(96,165,250,.52); --bt-bg:#3B82F6;--bt-tint:rgba(59,130,246,.30); --bt-dot:rgba(96,165,250,.60); --bt-txt:#93C5FD; --bt-base:rgba(8,16,44,0.88);}
  .bt-files {--bt-border:rgba(245,158,11,.52);  --bt-bg:#F59E0B;--bt-tint:rgba(245,158,11,.30); --bt-dot:rgba(251,191,36,.60); --bt-txt:#FCD34D; --bt-base:rgba(22,14,4,0.88);}
  .bt-audio {--bt-border:rgba(16,185,129,.52);  --bt-bg:#10B981;--bt-tint:rgba(16,185,129,.30); --bt-dot:rgba(52,211,153,.60);  --bt-txt:#6EE7B7; --bt-base:rgba(4,20,14,0.88);}
  .bt-links {--bt-border:rgba(239,68,68,.52);   --bt-bg:#EF4444;--bt-tint:rgba(239,68,68,.30);  --bt-dot:rgba(248,113,113,.60); --bt-txt:#FCA5A5; --bt-base:rgba(26,6,6,0.88);}
  .bt-video {--bt-border:rgba(167,139,250,.52); --bt-bg:#8B5CF6;--bt-tint:rgba(139,92,246,.30); --bt-dot:rgba(167,139,250,.60); --bt-txt:#C4B5FD; --bt-base:rgba(12,6,28,0.88);}
  .bt-notes {--bt-border:rgba(34,211,238,.52);  --bt-bg:#06B6D4;--bt-tint:rgba(6,182,212,.30);  --bt-dot:rgba(34,211,238,.60);  --bt-txt:#67E8F9; --bt-base:rgba(4,18,24,0.88);}
  .bt-email {--bt-border:rgba(107,191,158,.52); --bt-bg:#6BBF9E;--bt-tint:rgba(107,191,158,.30);--bt-dot:rgba(107,191,158,.60); --bt-txt:#a7dfc8;  --bt-base:rgba(4,18,14,0.88);}

  /* tile header */
  .bento-hdr{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:4px;}
  .bento-icon{width:30px;height:30px;border-radius:8px;border:1px solid var(--bt-border);
    background:rgba(0,0,0,0.35);display:flex;align-items:center;justify-content:center;color:var(--bt-txt);}
  .bento-icon svg{width:14px;height:14px;stroke:currentColor;fill:none;stroke-width:1.8;stroke-linecap:round;stroke-linejoin:round;}
  .bento-badge{font-size:.62rem;font-weight:700;letter-spacing:.02em;
    background:var(--bt-bg);color:#fff;border-radius:20px;padding:2px 8px;white-space:nowrap;}

  /* dot fill texture */
  .bento-dots{flex:1;min-height:28px;margin:5px 0 4px;
    background-image:radial-gradient(circle,var(--bt-dot) 1.6px,transparent 1.6px);
    background-size:9px 9px;background-position:1px 3px;}

  /* tile footer */
  .bento-name{font-size:.82rem;font-weight:700;color:#fff;letter-spacing:-.01em;line-height:1.2;text-shadow:0 1px 3px rgba(0,0,0,.5);}
  .bento-count{font-size:.67rem;color:var(--bt-txt);font-weight:500;margin-top:2px;
    display:flex;align-items:center;gap:4px;}
  .bento-count-dot{width:5px;height:5px;border-radius:50%;background:var(--bt-bg);flex-shrink:0;}

  /* Notes tile: horizontal layout */
  .bt-notes .bento-notes-body{display:flex;flex-direction:column;justify-content:space-between;padding:2px 0;min-width:0;}
  .bt-notes .bento-notes-right{display:flex;flex-direction:column;align-items:flex-end;justify-content:space-between;
    flex:1;min-width:0;padding-left:10px;}
  .bt-notes .bento-dots{flex:none;height:10px;min-height:unset;
    background-size:12px 10px;background-position:right center;}
  .time-chip{font-size:10px;font-weight:500;color:var(--accent);background:rgba(16,185,129,0.08);border:1px solid rgba(16,185,129,0.22);border-radius:4px;padding:1px 6px;white-space:nowrap;flex-shrink:0;}
  #joke-modal{position:fixed;inset:0;z-index:8500;background:rgba(0,0,0,0.72);display:none;align-items:center;justify-content:center;padding:24px;pointer-events:all;}
  #joke-modal.open{display:flex;}
  .joke-card{background:var(--bg-card);border-radius:8px;padding:30px 26px 26px;max-width:300px;width:100%;text-align:center;box-shadow:0 12px 40px rgba(0,0,0,0.3);}
  .joke-laser-wrap{position:relative;height:28px;margin-bottom:18px;overflow:hidden;}
  .joke-laser-track{position:absolute;top:50%;left:0;right:0;height:2px;transform:translateY(-50%);background:linear-gradient(to right,transparent 0%,rgba(16,185,129,.08) 30%,rgba(16,185,129,.08) 70%,transparent 100%);}
  .joke-laser-dot{position:absolute;top:50%;width:8px;height:8px;border-radius:50%;background:#10b981;box-shadow:0 0 6px 2px rgba(16,185,129,.5);transform:translate(-50%,-50%);animation:laserSlide 1.8s ease-in-out infinite alternate,laserSize 1.8s ease-in-out infinite alternate;}
  .joke-laser-glow{position:absolute;top:50%;width:22px;height:22px;border-radius:50%;background:radial-gradient(circle,rgba(16,185,129,.35) 0%,transparent 70%);transform:translate(-50%,-50%);animation:laserSlide 1.8s ease-in-out infinite alternate;}
  @keyframes laserSlide{
    0%  {left:4%;  opacity:.22;}
    50% {left:50%; opacity:1;}
    100%{left:96%; opacity:.22;}
  }
  @keyframes laserSize{
    0%  {width:5px; height:5px; box-shadow:0 0 4px 1px rgba(16,185,129,.35);}
    50% {width:12px;height:12px;box-shadow:0 0 20px 7px rgba(16,185,129,.75),0 0 44px 14px rgba(16,185,129,.22);}
    100%{width:5px; height:5px; box-shadow:0 0 4px 1px rgba(16,185,129,.35);}
  }
  .joke-label{font-size:10px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--text-muted);margin-bottom:16px;}
  .joke-lines{min-height:110px;display:flex;flex-direction:column;gap:8px;justify-content:center;}
  .joke-line{font-family:'Inter',sans-serif;font-size:var(--fs-sm);color:var(--text-primary);line-height:1.5;}
  .joke-line.q{color:var(--text-muted);font-style:italic;}
  .joke-line.setup{font-weight:600;}
  .joke-line.punchline{color:var(--accent);font-weight:700;font-size:var(--fs-base);}
  .joke-cursor{display:inline-block;width:2px;height:.85em;background:var(--accent);vertical-align:text-bottom;margin-left:1px;animation:jblink .55s step-end infinite;}
  @keyframes jblink{50%{opacity:0;}}

  /* ============================================================
     CALENDAR
  ============================================================ */
  /* Calendar header (refreshed 2026-06-01): now a 2-row flex container —
     row 1 = view switcher (Month/Week), row 2 = nav arrows + tappable month
     label + Today chip + next-arrow. Arrows bumped from 34×34 → 44×44 for
     accessibility (Apple HIG min). */
  .cal-header{display:flex;flex-direction:column;gap:8px;margin-bottom:16px;
    background:rgba(255,255,255,0.84);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);
    border:1px solid rgba(255,255,255,0.6);border-radius:8px;padding:10px;box-shadow:0 2px 12px rgba(0,0,0,0.06);}
  html[data-theme="dark"] .cal-header{background:rgba(22,27,34,0.88);border-color:rgba(255,255,255,0.07);}
  .cal-nav-row{display:flex;align-items:center;justify-content:space-between;gap:6px;}
  .cal-nav{width:44px;height:44px;border:1px solid var(--line-color);border-radius:4px;background:var(--bg-card);
    display:flex;align-items:center;justify-content:center;cursor:pointer;
    font-size:1.35rem;color:var(--text-muted);transition:all 0.15s;box-shadow:var(--shadow);
    touch-action:manipulation;flex-shrink:0;}
  .cal-nav:hover{border-color:var(--accent);color:var(--accent);background:rgba(16,185,129,0.05);}
  .cal-today-chip{
    display:flex;align-items:center;gap:4px;
    padding:6px 10px;border-radius:4px;min-height:36px;
    background:rgba(16,185,129,0.12);border:1.5px solid rgba(16,185,129,0.35);
    font-size:.65rem;font-weight:700;letter-spacing:.04em;text-transform:uppercase;
    color:var(--accent);cursor:pointer;white-space:nowrap;transition:background .15s;
    touch-action:manipulation;flex-shrink:0;
  }
  .cal-today-chip:active{background:rgba(16,185,129,0.25);}
  .cal-today-chip svg{width:11px;height:11px;stroke:currentColor;stroke-width:2.2;fill:none;flex-shrink:0;}
  /* Tappable month label — chevron telegraphs "opens picker" affordance.
     Uses 6px radius (design-system squared/luxe — no pills). */
  .cal-month-label{
    flex:1;min-width:0;display:flex;align-items:center;justify-content:center;gap:6px;
    background:transparent;border:1px solid transparent;border-radius:6px;
    padding:6px 8px;cursor:pointer;font-family:'Inter',sans-serif;
    font-size:clamp(1rem,3.6vw,1.25rem);font-weight:800;
    letter-spacing:-0.04em;color:#080808;
    touch-action:manipulation;transition:background .15s, border-color .15s;
    text-align:center;
  }
  .cal-month-label:hover{background:rgba(16,185,129,0.06);border-color:rgba(16,185,129,0.18);}
  .cal-month-label:active{background:rgba(16,185,129,0.12);}
  .cal-month-label .cal-chev{width:13px;height:13px;color:var(--text-muted);flex-shrink:0;}
  html[data-theme="dark"] .cal-month-label{color:#f0f2f5;}
  /* Legacy ".cal-month" kept as alias for backward-compat (still used by
     the dashboard mini-card label etc.) */
  .cal-month{font-family:'Inter',sans-serif;font-size:clamp(1.1rem,4vw,1.4rem);font-weight:800;
    letter-spacing:-0.04em;color:#080808;}
  html[data-theme="dark"] .cal-month{color:#f0f2f5;}

  /* Month/Week segmented control. Design-system squared corners (6px outer,
     4px inner). Active = accent fill; inactive = subtle hover treatment. */
  .cal-view-switcher{display:flex;align-items:center;gap:2px;padding:3px;
    background:var(--bg-elevated);border:1px solid var(--line-color);border-radius:6px;
    align-self:center;}
  .cal-view-btn{
    flex:1;min-width:80px;padding:8px 14px;border:none;background:transparent;
    border-radius:4px;font-family:'Inter',sans-serif;font-size:var(--fs-sm);font-weight:700;
    letter-spacing:.04em;text-transform:uppercase;color:var(--text-secondary);
    cursor:pointer;transition:background .15s,color .15s;
    touch-action:manipulation;min-height:36px;
  }
  .cal-view-btn:hover{color:var(--text-primary);background:rgba(16,185,129,0.06);}
  .cal-view-btn.is-active{background:var(--accent);color:#fff;box-shadow:0 1px 3px rgba(16,185,129,0.35);}
  .cal-view-btn.is-active:hover{background:var(--accent);}
  .cal-grid{background:var(--bg-card);border:1px solid var(--line-color);border-radius:8px;
    overflow:hidden;box-shadow:var(--shadow);}
  .cal-weekdays{display:grid;grid-template-columns:repeat(7,1fr);background:var(--bg-elevated);border-bottom:1px solid var(--line-color);}
  .cal-weekday{text-align:center;padding:8px 4px;font-size:.55rem;font-weight:400;color:var(--text-muted);text-transform:uppercase;letter-spacing:.22em;}
  .cal-days{display:grid;grid-template-columns:repeat(7,1fr);}
  .cal-day{min-height:50px;padding:6px 4px 4px;border-right:1px solid var(--line-color);border-bottom:1px solid var(--line-color);
    display:flex;flex-direction:column;align-items:center;gap:3px;cursor:pointer;transition:background 0.12s;position:relative;}
  /* Slow-glow indicator for unviewed shared items (calendar days, file cards) */
  @keyframes share-pulse {
    0%,100% { transform:scale(1);    opacity:.95; box-shadow:0 0 0 0 rgba(16,185,129,0.55); }
    50%     { transform:scale(1.25); opacity:.55; box-shadow:0 0 0 4px rgba(16,185,129,0);    }
  }
  .share-glow-dot{position:absolute;top:3px;right:3px;width:6px;height:6px;
    background:#10B981;border-radius:50%;
    animation:share-pulse 2.2s ease-in-out infinite;pointer-events:none;}
  .cal-day:nth-child(7n){border-right:none;} .cal-day:hover{background:var(--bg-elevated);}
  .cal-day.empty{cursor:default;pointer-events:none;} .cal-day.empty:hover{background:transparent;}
  .cal-day.today .day-num{background:var(--accent);color:var(--bg-primary);font-weight:500;}
  .cal-moon{display:block;width:10px;height:10px;margin:1px auto 0;flex-shrink:0;}
  .cal-moon circle{fill:#E8D8FF;stroke:#9B7FCA;stroke-width:1.5;}
  html[data-theme="dark"] .cal-moon circle{fill:#7B5EA7;stroke:#C4A8F0;}
  .cal-day.has-events{cursor:pointer;}
  .cal-day.has-events:hover .day-num{text-decoration:underline;text-underline-offset:2px;}
  .day-num{font-family:var(--font-ui);font-size:var(--fs-xs);font-weight:300;color:var(--text-primary);
    width:22px;height:22px;display:flex;align-items:center;justify-content:center;}
  .day-badges{display:flex;flex-wrap:wrap;justify-content:center;gap:2px;}
  .day-dot{width:5px;height:5px;border-radius:50%;}
  .day-dot.green{background:var(--accent);} .day-dot.red{background:#E86A4A;}
  .day-dot.orange{background:#D4A847;} .day-dot.blue{background:#7EAED4;}
  .day-dot.purple{background:#B088CC;} .day-dot.pink{background:#F472B6;}
  .cal-legend{display:flex;flex-wrap:wrap;gap:10px;margin-top:12px;padding:12px 14px;
    background:var(--bg-card);border:1px solid var(--line-color);border-radius:8px;box-shadow:var(--shadow);}
  .legend-item{display:flex;align-items:center;gap:6px;font-size:.6rem;color:var(--text-muted);font-weight:500;}
  .cal-events{margin-top:16px;}
  .cal-event{display:flex;gap:12px;padding:13px 14px;background:var(--bg-card);
    border:1px solid var(--line-color);border-radius:8px;margin-bottom:8px;
    transition:background 0.15s,border-color 0.15s;cursor:pointer;box-shadow:var(--shadow);}
  .cal-event:hover{background:var(--card-hover-bg);border-color:rgba(16,185,129,0.3);}
  .event-line{width:3px;border-radius:2px;flex-shrink:0;} .event-body{flex:1;}
  .event-title{font-size:var(--fs-sm);font-weight:500;color:var(--text-primary);}
  .event-time{font-size:var(--fs-xs);color:var(--text-muted);margin-top:3px;}

  /* ============================================================
     VOICE / VIDEO RECORDING
  ============================================================ */
  .record-row{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-bottom:12px;
    background:rgba(255,255,255,0.84);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);
    border:1px solid rgba(255,255,255,0.6);border-radius:8px;padding:10px;box-shadow:0 2px 12px rgba(0,0,0,0.06);}
  html[data-theme="dark"] .record-row{background:rgba(22,27,34,0.88);border-color:rgba(255,255,255,0.07);}
  .record-btn{display:flex;align-items:center;justify-content:center;gap:8px;padding:13px 10px;
    background:var(--bg-card);border:1px solid var(--line-color);border-radius:6px;
    cursor:pointer;transition:all 0.15s;font-family:'Inter',sans-serif;font-size:var(--fs-sm);
    font-weight:600;color:var(--text-primary);box-shadow:var(--shadow);}
  .record-btn svg{width:16px;height:16px;stroke:currentColor;fill:none;stroke-width:2;stroke-linecap:round;flex-shrink:0;}
  .record-btn:hover{border-color:var(--accent);color:var(--accent);}
  .record-btn.recording{border-color:#ef4444;color:#ef4444;background:rgba(239,68,68,0.06);animation:recPulse 1.4s ease-in-out infinite;}
  @keyframes recPulse{0%,100%{box-shadow:0 0 0 0 rgba(239,68,68,0.25)}50%{box-shadow:0 0 0 6px rgba(239,68,68,0)}}
  .rec-dot{width:8px;height:8px;border-radius:50%;background:#ef4444;flex-shrink:0;animation:recPulse 1.4s ease-in-out infinite;}

  /* Recording status bar (voice, inline) */
  #voice-status{display:none;align-items:center;gap:10px;padding:10px 14px;
    background:rgba(255,255,255,0.92);border:1px solid rgba(239,68,68,0.25);
    border-radius:8px;margin-bottom:12px;box-shadow:0 2px 10px rgba(0,0,0,0.08);}
  html[data-theme="dark"] #voice-status{background:rgba(30,20,20,0.92);}
  #voice-status.visible{display:flex;}
  #voice-timer{font-family:'Inter',sans-serif;font-size:var(--fs-sm);font-weight:700;color:#ef4444;min-width:36px;}
  .voice-stop-btn{margin-left:auto;padding:5px 12px;background:#ef4444;color:#fff;border:none;
    border-radius:4px;font-family:'Inter',sans-serif;font-size:var(--fs-xs);font-weight:700;cursor:pointer;transition:background 0.15s;}
  .voice-stop-btn:hover{background:#dc2626;}

  /* Saved toast */
  #rec-toast{position:fixed;bottom:90px;left:50%;transform:translateX(-50%) translateY(20px);
    background:var(--text-primary);color:var(--bg-primary);padding:10px 20px;border-radius:8px;
    font-family:'Inter',sans-serif;font-size:var(--fs-sm);font-weight:600;
    opacity:0;transition:opacity 0.3s,transform 0.3s;pointer-events:none;z-index:9999;white-space:nowrap;}
  #rec-toast.show{opacity:1;transform:translateX(-50%) translateY(0);}
  /* Share-notification variant — green left-border, tappable */
  #rec-toast.share{border-left:4px solid #10B981;padding-left:14px;}
  #rec-toast.tappable{pointer-events:auto;cursor:pointer;}

  /* Video recording modal */
  #video-modal{position:fixed;inset:0;z-index:7000;background:rgba(0,0,0,0.88);
    display:none;flex-direction:column;align-items:center;justify-content:center;padding:20px;}
  #video-modal.open{display:flex;}
  #video-preview{width:100%;max-width:400px;max-height:55dvh;border-radius:10px;
    background:#000;object-fit:cover;display:block;}
  .video-modal-controls{display:flex;align-items:center;gap:16px;margin-top:18px;}
  #video-timer{font-family:'Inter',sans-serif;font-size:1.4rem;font-weight:700;color:#fff;min-width:60px;text-align:center;}
  .video-rec-dot{width:10px;height:10px;border-radius:50%;background:#ef4444;animation:recPulse 1.4s ease-in-out infinite;}
  .video-stop-btn{padding:11px 24px;background:#ef4444;color:#fff;border:none;border-radius:6px;
    font-family:'Inter',sans-serif;font-size:var(--fs-base);font-weight:700;cursor:pointer;transition:background 0.15s;}
  .video-stop-btn:hover{background:#dc2626;}
  .video-cancel-btn{padding:11px 18px;background:transparent;color:rgba(255,255,255,0.6);border:1px solid rgba(255,255,255,0.25);
    border-radius:6px;font-family:'Inter',sans-serif;font-size:var(--fs-sm);font-weight:500;cursor:pointer;transition:all 0.15s;}
  .video-cancel-btn:hover{border-color:rgba(255,255,255,0.5);color:#fff;}

  /* Add-event — now a modal, not inline */
  .add-event-input{width:100%;padding:9px 12px;background:var(--form-input-bg);border:1px solid var(--line-color);
    border-radius:4px;font-family:'Inter',sans-serif;font-size:var(--fs-sm);color:var(--text-primary);
    outline:none;margin-bottom:8px;box-sizing:border-box;}
  .add-event-input:focus{border-color:var(--accent);box-shadow:0 0 0 3px rgba(16,185,129,0.1);}
  .add-event-row{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-bottom:8px;}
  /* Time select picker */
  .tp-section-label{font-size:.58rem;font-weight:700;letter-spacing:.09em;text-transform:uppercase;
    color:var(--text-muted);margin-bottom:8px;}
  .tp-allday-row{display:flex;align-items:center;gap:8px;margin-bottom:10px;}
  .tp-allday-row label{font-size:.78rem;font-weight:600;color:var(--text-secondary);cursor:pointer;}
  .tp-allday-row input[type=checkbox]{width:16px;height:16px;accent-color:var(--accent);cursor:pointer;}
  .tp-select-wrap{display:flex;align-items:center;gap:6px;margin-bottom:4px;}
  .tp-sel-input{padding:9px 8px;background:var(--form-input-bg);border:1px solid var(--line-color);
    border-radius:4px;font-family:'Inter',sans-serif;font-size:.92rem;font-weight:600;
    color:var(--text-primary);outline:none;cursor:pointer;-webkit-appearance:auto;appearance:auto;}
  .tp-sel-input:focus{border-color:var(--accent);box-shadow:0 0 0 3px rgba(16,185,129,0.1);}
  #tpHourSel{width:62px;}
  #tpMinSel{width:68px;}
  #tpAmpmSel{width:66px;}
  .tp-colon{font-size:1.2rem;font-weight:800;color:var(--text-secondary);margin:0 -2px;}
  .add-event-submit{width:100%;padding:9px;background:var(--accent);color:#000;border:none;border-radius:4px;
    font-family:'Inter',sans-serif;font-size:var(--fs-sm);font-weight:700;cursor:pointer;transition:background 0.15s;}
  .add-event-submit:hover{background:var(--accent-hover);}
  /* [+] button beside Coming Up label */
  .cal-add-btn{width:26px;height:26px;border-radius:6px;border:1.5px solid var(--line-color);
    background:var(--bg-card);cursor:pointer;display:flex;align-items:center;justify-content:center;
    flex-shrink:0;transition:border-color .15s,background .15s;}
  .cal-add-btn:hover{border-color:var(--accent);background:rgba(16,185,129,0.08);}
  .cal-add-btn svg{width:13px;height:13px;stroke:var(--accent);fill:none;stroke-width:2.5;stroke-linecap:round;}
  /* Add-entry modal — centered dialog */
  #add-event-overlay{position:fixed;inset:0;z-index:6500;background:rgba(0,0,0,0);
    pointer-events:none;transition:background .22s;
    display:flex;align-items:center;justify-content:center;padding:24px 16px;}
  #add-event-overlay.open{background:rgba(0,0,0,0.62);pointer-events:all;}
  #add-event-panel{width:100%;max-width:360px;background:var(--bg-card);border-radius:12px;
    padding:20px 20px 24px;
    transform:scale(0.93) translateY(16px);opacity:0;
    transition:transform .26s cubic-bezier(.25,1,.5,1),opacity .22s ease;
    box-shadow:0 16px 48px rgba(0,0,0,0.32);}
  #add-event-overlay.open #add-event-panel{transform:scale(1) translateY(0);opacity:1;}
  .aev-handle{display:none;}
  /* date chip above title */
  .aev-date-chip{display:inline-flex;align-items:center;gap:5px;
    background:rgba(16,185,129,0.10);border:1.5px solid rgba(16,185,129,0.30);
    border-radius:6px;padding:3px 9px;margin-bottom:10px;}
  .aev-date-chip-mon{font-size:.6rem;font-weight:700;letter-spacing:.04em;text-transform:uppercase;color:var(--accent);}
  .aev-date-chip-day{font-size:.82rem;font-weight:800;letter-spacing:-.02em;color:var(--text-primary);}
  .aev-date-chip-dow{font-size:.6rem;font-weight:600;color:var(--text-muted);letter-spacing:.02em;}
  .aev-modal-hdr{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:14px;}
  .aev-close-btn{width:26px;height:26px;border-radius:6px;border:1px solid var(--line-color);
    background:none;cursor:pointer;display:flex;align-items:center;justify-content:center;flex-shrink:0;}
  .aev-close-btn svg{width:12px;height:12px;stroke:var(--text-muted);fill:none;stroke-width:2.5;stroke-linecap:round;}
  .aev-title{font-size:.95rem;font-weight:700;color:var(--text-primary);letter-spacing:-.02em;}
  /* category chip scroller — Region 3 */
  .aev-cat-label{font-size:.58rem;font-weight:700;letter-spacing:.09em;text-transform:uppercase;
    color:var(--text-muted);margin-bottom:6px;margin-top:10px;}
  .aev-cat-row{display:flex;gap:6px;overflow-x:auto;padding-bottom:4px;-webkit-overflow-scrolling:touch;}
  .aev-cat-row::-webkit-scrollbar{display:none;}
  .aev-cat-chip{flex-shrink:0;padding:5px 12px;border-radius:20px;border:1.5px solid var(--line-color);
    background:none;font-family:'Inter',sans-serif;font-size:.72rem;font-weight:600;
    color:var(--text-secondary);cursor:pointer;white-space:nowrap;transition:border-color .15s,background .15s,color .15s;}
  .aev-cat-chip.active{border-color:var(--accent);background:rgba(16,185,129,0.12);color:var(--accent);}
  .aev-cat-chip.aev-cat-add{border-style:dashed;color:var(--text-muted);}
  .user-event-badge{display:inline-block;font-size:.5rem;font-weight:700;letter-spacing:.08em;
    text-transform:uppercase;background:rgba(16,185,129,0.12);color:var(--accent);
    border:1px solid rgba(16,185,129,0.25);border-radius:3px;padding:1px 5px;margin-left:6px;vertical-align:middle;}

  /* Day event list inside modal */
  /* ── Calendar day modal — compact spacing ─────────────────────────────────
     .cal-day-mode is added to #detail-panel by openCalDay() and removed by closeDetail().
     Scoped so other panels (File Vault, connections, etc.) keep their current padding. */
  #detail-panel.cal-day-mode .detail-drag-handle { margin:3px auto 0; }
  #detail-panel.cal-day-mode .detail-header { padding:5px 20px 4px; }
  #detail-panel.cal-day-mode .detail-body { padding:5px 10px 0; }
  #detail-panel.cal-day-mode .detail-section-label { margin-bottom:3px; }
  /* action bar bleeds to 10px body padding edges (halved from default 20px) */
  #detail-panel.cal-day-mode .ev-action-bar { margin:6px -10px 0; }
  /* "+ Add an entry for this day" — refreshed 2026-06-01: bigger font + real
     tap-target padding + accent-tinted background so it reads as a button, not
     an afterthought link. Extra bottom margin pushes the "What you can do"
     accordion further down so the two no longer collide under a finger tap. */
  .day-add-entry-wrap { padding:14px 0 4px; margin-bottom:24px; }
  .day-add-entry-btn {
    display:flex; align-items:center; justify-content:center; gap:8px;
    width:100%; padding:14px 18px;
    background:rgba(16,185,129,0.08); color:var(--accent);
    border:1.5px solid rgba(16,185,129,0.30); border-radius:6px;
    font-family:'Inter',sans-serif; font-size:var(--fs-base); font-weight:700;
    letter-spacing:-0.01em; cursor:pointer;
    transition:background .15s, border-color .15s;
    touch-action:manipulation; min-height:44px;
  }
  .day-add-entry-btn svg { width:18px; height:18px; flex-shrink:0; }
  .day-add-entry-btn:hover, .day-add-entry-btn:active {
    background:rgba(16,185,129,0.16); border-color:rgba(16,185,129,0.55);
  }
  /* ── Appointment card — column layout so action bar spans full width ──── */
  .day-event-item{padding:8px 0;border-bottom:1px solid var(--line-color);display:flex;flex-direction:column;gap:0;}
  .day-event-item:last-child{border-bottom:none;padding-bottom:0;} .day-event-item:first-child{padding-top:0;}
  .day-event-item.ev-done{opacity:0.5;}
  /* ── Horizontal action bar — bleeds to panel edges via -20px margin ────── */
  .ev-action-bar{display:flex;margin:6px -20px 0;border-top:1px solid var(--line-color);}
  .ev-act-btn{flex:1;min-height:36px;background:none;border:none;border-right:1px solid var(--line-color);
    cursor:pointer;display:flex;align-items:center;justify-content:center;
    font-family:inherit;font-size:.72rem;font-weight:700;transition:background .15s;
    touch-action:manipulation;padding:0;}
  .ev-act-btn:last-child{border-right:none;}
  .ev-act-btn:active{background:rgba(0,0,0,0.06);}
  .ev-act-edit{color:var(--accent);}
  .ev-act-attach{color:#60A5FA;}
  .ev-act-share{color:#7B5FA0;}
  .ev-act-erase{color:#ef4444;}
  /* Ag2 fix: brief highlight pulse drawn around a share row when a deep-link
     deposits the user here. Two cycles of soft purple glow + a faint background
     wash; auto-removed by openCalDay after 2.4s. */
  .day-event-item.share-focus-pulse{animation:shareFocusPulse 1.2s ease-out 2;border-radius:8px;}
  @keyframes shareFocusPulse{
    0%   { box-shadow: 0 0 0 0 rgba(176,136,204,.55); background:rgba(176,136,204,.18); }
    60%  { box-shadow: 0 0 0 10px rgba(176,136,204,0); background:rgba(176,136,204,.08); }
    100% { box-shadow: 0 0 0 0 rgba(176,136,204,0); background:rgba(176,136,204,.06); }
  }
  .day-event-item.ev-done .day-event-title{text-decoration:line-through;color:var(--text-muted);}
  .day-event-item.ev-done .day-event-bar{background:#9ca3af !important;}
  .day-event-bar{width:3px;border-radius:2px;flex-shrink:0;align-self:stretch;}
  .day-event-content{flex:1;}
  /* Done toggle button */
  .ev-done-btn{width:28px;height:28px;border-radius:50%;border:2px solid rgba(107,114,128,.4);
    background:none;cursor:pointer;display:flex;align-items:center;justify-content:center;
    flex-shrink:0;transition:all .18s;color:var(--text-muted);touch-action:manipulation;}
  .ev-done-btn:hover{border-color:var(--accent);color:var(--accent);}
  /* Done state: thick green ring, soft green wash, bold green check — "all bold green" */
  .ev-done-btn.is-done{background:rgba(16,185,129,0.14);border-color:var(--accent);border-width:2.5px;color:var(--accent);box-shadow:0 0 0 3px rgba(16,185,129,0.10);}
  .ev-done-btn svg{width:13px;height:13px;stroke:currentColor;fill:none;stroke-width:2.8;stroke-linecap:round;stroke-linejoin:round;transition:stroke-width .18s;}
  .ev-done-btn.is-done svg{stroke-width:3.6;}
  /* Completed tick on calendar grid day */
  .cal-day .day-done-check{font-size:8px;color:var(--accent);line-height:1;margin-top:1px;display:block;text-align:center;}
  .day-event-cat{font-size:.55rem;letter-spacing:.2em;text-transform:uppercase;font-weight:400;margin-bottom:4px;opacity:0.75;}
  .day-event-title{font-size:var(--fs-sm);font-weight:400;color:var(--text-primary);margin-bottom:3px;}
  .day-event-time{font-size:var(--fs-xs);color:var(--text-muted);font-weight:500;}
  .day-event-detail{font-size:var(--fs-xs);color:var(--text-secondary);margin-top:6px;line-height:1.6;font-weight:300;}

  /* ============================================================
     CALENDAR — WEEKLY VIEW (2026-06-01)
     7-column horizontal scroll-snap grid. Each column is 20% wide so
     exactly 5 days are visible at any time; remaining 2 days reached
     via natural horizontal swipe. Each event row is "HH:MM Title"
     (compressed); a dedicated magnifier icon on the right triggers
     Zooming Hold (press-hold → row expands in place revealing detail).
  ============================================================ */
  .cal-week-view{
    background:var(--bg-card);border:1px solid var(--line-color);border-radius:8px;
    overflow:hidden;box-shadow:var(--shadow);
  }
  .cal-week-scroller{
    display:grid;grid-auto-flow:column;
    grid-auto-columns:20%;            /* exactly 5 visible at 100% width */
    overflow-x:auto;overflow-y:hidden;
    scroll-snap-type:x mandatory;
    scrollbar-width:thin;
    -webkit-overflow-scrolling:touch;
    min-height:260px;
  }
  .cal-week-scroller::-webkit-scrollbar{height:6px;}
  .cal-week-scroller::-webkit-scrollbar-thumb{background:var(--line-strong);border-radius:3px;}
  .cal-week-col{
    scroll-snap-align:start;
    display:flex;flex-direction:column;
    border-right:1px solid var(--line-color);
    background:var(--bg-card);
    /* Stacking context — needed so :has(.is-zoomed) can lift this column
       above siblings so the zoomed row visibly floats over neighbor days. */
    position:relative;z-index:1;
    min-width:0;            /* allow children to render wider than the track */
    overflow:visible;       /* zoomed row spills past column boundaries */
  }
  .cal-week-col:last-child{border-right:none;}
  .cal-week-col.is-today{background:rgba(16,185,129,0.04);}
  /* When any child row is zoomed, hoist this column above its neighbors so
     the zoomed line floats on top instead of being painted over by adjacent
     column backgrounds. :has() supported on iOS 15.4+, Chrome 105+, FF 121+ —
     baseline for WH's audience. Pure-CSS solution, no JS coordination. */
  .cal-week-col:has(.cal-week-ev.is-zoomed){z-index:100;}
  .cal-week-col-hdr{
    padding:8px 6px 6px;border-bottom:1px solid var(--line-color);
    text-align:center;cursor:pointer;transition:background .15s;
    background:var(--bg-elevated);
    position:sticky;top:0;z-index:2;
  }
  .cal-week-col-hdr:hover{background:rgba(16,185,129,0.06);}
  .cal-week-col.is-today .cal-week-col-hdr{background:rgba(16,185,129,0.10);}
  .cwc-wkd{font-size:.55rem;font-weight:400;letter-spacing:.22em;text-transform:uppercase;color:var(--text-muted);margin-bottom:2px;}
  .cwc-num{font-size:1.15rem;font-weight:800;color:var(--text-primary);letter-spacing:-0.02em;line-height:1;}
  .cal-week-col.is-today .cwc-num{color:var(--accent);}
  .cal-week-empty{
    padding:18px 4px 8px;text-align:center;font-size:.85rem;color:var(--text-muted);
  }

  /* Compressed event row in weekly view. Three children: a 3px color bar
     (cat color), the body (time + title), and the magnifier icon button. */
  .cal-week-ev{
    display:flex;align-items:stretch;gap:0;
    padding:0;margin:0;border-bottom:1px solid var(--line-color);
    background:var(--bg-card);
    position:relative;
    transition:background .12s ease, transform .18s cubic-bezier(.2,1,.3,1), box-shadow .18s ease;
    transform-origin:right center;
  }
  .cal-week-ev:last-child{border-bottom:none;}
  .cal-week-ev.is-done{opacity:0.5;}
  .cwev-bar{width:3px;background:var(--ev-color,#10b981);flex-shrink:0;}
  .cwev-body{flex:1;min-width:0;padding:8px 4px 8px 6px;cursor:pointer;}
  .cwev-line{
    display:flex;align-items:baseline;gap:6px;
    white-space:nowrap;overflow:hidden;text-overflow:ellipsis;
  }
  .cwev-time{
    font-size:.62rem;font-weight:700;color:var(--text-secondary);
    letter-spacing:.02em;flex-shrink:0;
  }
  .cwev-title{
    font-size:.78rem;font-weight:500;color:var(--text-primary);
    overflow:hidden;text-overflow:ellipsis;
  }
  /* Hidden by default; revealed in is-zoomed state */
  .cwev-expand{
    display:none;
    margin-top:6px;padding-top:6px;border-top:1px dashed var(--line-color);
  }
  .cwev-line2{font-size:var(--fs-xs);color:var(--text-secondary);font-weight:500;margin-bottom:4px;}
  .cwev-meta{font-size:var(--fs-xs);margin-bottom:4px;}
  .cwev-cat{font-size:.55rem;font-weight:700;letter-spacing:.18em;text-transform:uppercase;}
  .cwev-detail{font-size:var(--fs-xs);color:var(--text-secondary);line-height:1.45;}

  /* Magnifier (Zooming Hold trigger). Right edge of each row.
     ⊕ icon = magnifier with a + (signals "expand to see more"). */
  .cwev-zoom{
    flex-shrink:0;width:34px;display:flex;align-items:center;justify-content:center;
    background:transparent;border:none;border-left:1px solid var(--line-color);
    color:var(--text-muted);cursor:pointer;
    touch-action:none;            /* prevents scroll-on-hold; we own the gesture */
    transition:background .12s ease, color .12s ease;
    -webkit-user-select:none;user-select:none;
  }
  .cwev-zoom svg{width:14px;height:14px;}
  .cwev-zoom:hover{background:rgba(16,185,129,0.08);color:var(--accent);}
  .cwev-zoom:active{background:rgba(16,185,129,0.16);color:var(--accent);}

  /* The Zooming Hold expanded state — row grows in place revealing detail.
     Refined 2026-06-01: the row now FLOATS above adjacent day columns instead
     of being clipped by them. Mechanism: min-width:220px forces the row to
     render wider than its column track (which stays at 20%), while the
     parent column's :has()-bumped z-index ensures the overflowing content
     paints above neighbor columns. transform-origin:left center keeps the
     left edge anchored to the column so the magnifier visually stays put. */
  .cal-week-ev.is-zoomed{
    position:relative;z-index:100;
    background:var(--bg-card);
    min-width:220px;
    transform-origin:left center;
    transform:scale(1.06);
    box-shadow:0 8px 28px rgba(16,185,129,0.22), 0 0 0 1px rgba(16,185,129,0.35);
    border-radius:6px;
  }
  html[data-theme="dark"] .cal-week-ev.is-zoomed{background:var(--bg-elevated);}
  .cal-week-ev.is-zoomed .cwev-expand{display:block;}
  .cal-week-ev.is-zoomed .cwev-time,
  .cal-week-ev.is-zoomed .cwev-title{font-size:.92rem;}
  .cal-week-ev.is-zoomed .cwev-title{white-space:normal;}  /* allow wrap when wider */
  .cal-week-ev.is-zoomed .cwev-zoom{color:var(--accent);background:rgba(16,185,129,0.10);}
  /* Edge-case mirroring — when the zoomed row is in the rightmost columns
     (positions 6 or 7 of 7), expand LEFTWARD instead of rightward so the
     content doesn't get clipped by the scroller's overflow-x:auto boundary.
     Class .is-zoom-left is set by the JS Zooming Hold handler based on
     column index. transform-origin moves to the right side so the lens
     "grows" away from the right edge. */
  .cal-week-ev.is-zoomed.is-zoom-left{
    transform-origin:right center;
    /* shift the layout box leftward so it doesn't extend past the column on
       the right; achieved with negative left margin equal to extra width. */
    margin-left:calc(-1 * (220px - 100%));
  }
  @media (prefers-reduced-motion: reduce){
    .cal-week-ev{transition:background .12s ease;}
    .cal-week-ev.is-zoomed{transform:none;}
  }

  /* ============================================================
     ADVICE
  ============================================================ */
  .advice-hero{background:var(--bg-elevated);border:1px solid rgba(16,185,129,0.2);border-radius:8px;
    padding:22px 20px;margin-bottom:14px;position:relative;overflow:hidden;cursor:pointer;
    box-shadow:var(--shadow);}
  .advice-hero::after{content:'';position:absolute;bottom:-40px;right:-40px;width:140px;height:140px;
    background:radial-gradient(circle,rgba(16,185,129,0.12) 0%,transparent 65%);pointer-events:none;}
  .advice-hero-label{font-size:.6rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;
    color:var(--accent);margin-bottom:10px;}
  .advice-hero-text{font-family:'Inter',sans-serif;font-size:clamp(1rem,3vw,1.2rem);font-weight:500;
    color:var(--text-primary);line-height:1.55;position:relative;z-index:1;}
  .advice-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-bottom:14px;}
  .advice-tile{background:var(--bg-card);border:1px solid var(--line-color);border-radius:8px;
    padding:16px 14px;cursor:pointer;transition:border-color 0.15s,background 0.15s;box-shadow:var(--shadow);}
  .advice-tile:hover{border-color:rgba(16,185,129,0.4);background:var(--card-hover-bg);}
  .advice-tile.tile-invite .advice-tile-icon{background:rgba(16,185,129,0.06);border-color:rgba(16,185,129,0.2);color:var(--accent);}
  .advice-tile.tile-invite .advice-tile-sub{color:var(--accent);font-weight:500;}
  .advice-tile-icon{width:28px;height:28px;border:1px solid rgba(16,185,129,0.25);border-radius:6px;
    background:rgba(16,185,129,0.08);display:flex;align-items:center;justify-content:center;margin-bottom:10px;color:var(--accent);}
  .advice-tile-title{font-size:var(--fs-sm);font-weight:600;color:var(--text-primary);margin-bottom:3px;}
  .advice-tile-sub{font-size:var(--fs-xs);color:var(--text-muted);font-weight:400;}
  /* Budget modal */
  #budgetModal{position:fixed;inset:0;background:rgba(0,0,0,0.55);z-index:1100;display:flex;
    align-items:center;justify-content:center;padding:20px 16px;opacity:0;pointer-events:none;transition:opacity .2s;}
  #budgetModal.open{opacity:1;pointer-events:all;}
  #budgetModalPanel{background:var(--bg-elevated);border-radius:12px;width:100%;max-width:400px;
    max-height:88dvh;overflow-y:auto;padding:22px 20px 28px;transform:scale(0.94);opacity:0;transition:transform .2s,opacity .2s;}
  #budgetModal.open #budgetModalPanel{transform:scale(1);opacity:1;}
  .budget-modal-hdr{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:18px;}
  .budget-modal-title{font-size:1rem;font-weight:700;color:var(--text-primary);}
  .budget-modal-sub{font-size:.75rem;color:var(--text-muted);margin-top:3px;}
  .budget-field-label{font-size:.7rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--text-muted);margin-bottom:5px;margin-top:14px;}
  .budget-field-label:first-child{margin-top:0;}
  .budget-input{width:100%;background:var(--bg-card);border:1.5px solid var(--line-color);border-radius:6px;
    padding:10px 12px;font-family:'Inter',sans-serif;font-size:.9rem;color:var(--text-primary);
    outline:none;box-sizing:border-box;transition:border-color .15s;}
  .budget-input:focus{border-color:var(--accent);}
  .budget-expense-row{display:flex;gap:8px;margin-bottom:8px;align-items:flex-start;}
  .budget-expense-row .budget-input{flex:1;}
  .budget-expense-row button{width:34px;height:38px;flex-shrink:0;background:none;border:1.5px solid rgba(239,68,68,.4);
    border-radius:6px;color:#ef4444;cursor:pointer;font-size:1.1rem;display:flex;align-items:center;justify-content:center;padding:0;}
  .budget-add-btn{background:none;border:1.5px dashed var(--line-color);border-radius:6px;
    width:100%;padding:9px;font-family:'Inter',sans-serif;font-size:.78rem;color:var(--text-muted);
    cursor:pointer;margin-top:4px;transition:border-color .15s,color .15s;}
  .budget-add-btn:hover{border-color:var(--accent);color:var(--accent);}
  .budget-save-btn{width:100%;margin-top:20px;padding:13px;background:var(--accent);border:none;border-radius:6px;
    font-family:'Inter',sans-serif;font-size:.9rem;font-weight:700;color:#fff;cursor:pointer;
    transition:opacity .15s;}
  .budget-save-btn:hover{opacity:.88;}
  .budget-summary-item{display:flex;justify-content:space-between;padding:7px 0;border-bottom:1px solid var(--line-color);font-size:.82rem;}
  .budget-summary-item:last-child{border-bottom:none;}
  .budget-summary-label{color:var(--text-muted);}
  .budget-summary-val{font-weight:600;color:var(--text-primary);}
  .advice-card{background:var(--bg-card);border:1px solid var(--line-color);border-radius:8px;
    padding:16px;margin-bottom:10px;cursor:pointer;transition:background 0.15s,border-color 0.15s;box-shadow:var(--shadow);}
  .advice-card:hover{background:var(--card-hover-bg);border-color:rgba(16,185,129,0.3);}
  .advice-card-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px;}
  .advice-type{font-size:.6rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--text-muted);}
  .advice-text{font-size:var(--fs-sm);font-weight:400;color:var(--text-secondary);line-height:1.7;}
  .advice-source{font-size:var(--fs-xs);color:var(--text-muted);margin-top:10px;}
  .ewc-accordion-hdr{display:flex;align-items:center;gap:6px;padding:9px 12px;
    background:var(--bg-card);border:1.5px solid #F9A825;border-radius:8px;cursor:pointer;
    transition:border-radius 0.15s;margin-bottom:0;}
  .ewc-accordion-hdr.open{border-radius:8px 8px 0 0;}
  .ewc-accordion-label{font-size:.65rem;font-weight:700;text-transform:uppercase;letter-spacing:.07em;color:#E65100;flex:1;}
  .ewc-count-badge{background:#E65100;color:#fff;font-size:.6rem;font-weight:800;
    border-radius:4px;padding:2px 5px;flex-shrink:0;}
  .ewc-chevron{width:13px;height:13px;stroke:#E65100;transition:transform 0.2s;flex-shrink:0;}
  #emailWarningsList{border:1.5px solid #F9A825;border-top:none;border-radius:0 0 8px 8px;padding:8px 8px 0;margin-bottom:14px;}

  /* ============================================================
     BOTTOM NAV
  ============================================================ */
  .bottom-nav{width:100%;flex-shrink:0;display:flex;
    min-height:calc(52px + max(6px,env(safe-area-inset-bottom)));
    padding:4px 0 max(6px,env(safe-area-inset-bottom));
    background:var(--nav-bg-scrolled);border-top:1px solid var(--line-color);z-index:200;
    backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);transition:background 0.25s,border-color 0.25s;}
  .nav-item{flex:1;display:flex;flex-direction:column;align-items:center;gap:3px;padding:8px 4px 5px;
    cursor:pointer;border:none;background:transparent;color:var(--text-muted);
    font-family:'Inter',sans-serif;transition:color 0.15s;-webkit-tap-highlight-color:transparent;}
  .nav-item:hover{color:var(--accent);}
  .nav-item.active{color:var(--accent);}
  .nav-icon-wrap{position:relative;line-height:1;width:22px;height:22px;display:flex;align-items:center;justify-content:center;}
  .nav-icon-wrap svg{width:20px;height:20px;stroke:currentColor;fill:none;stroke-width:1.5;stroke-linecap:round;stroke-linejoin:round;}
  .nav-badge{position:absolute;top:-5px;right:-10px;background:#ef4444;color:#fff;border-radius:10px;
    font-size:8px;font-weight:700;font-family:'Inter',sans-serif;padding:1px 5px;min-width:15px;text-align:center;line-height:1.7;}
  /* Share badge — positive social signal (green), distinct from warning red */
  .nav-badge.share{background:#10B981;}
  #esNoteInput::placeholder{font-style:italic;}
  .nav-label{font-size:.55rem;font-weight:500;letter-spacing:.05em;text-transform:uppercase;line-height:1;}

  /* ============================================================
     ONBOARDING PIVOT S1b — Coach cards (Home empty state)
     Added 2026-05-28. Hidden by default ([hidden]); _renderCoachCards
     toggles visibility. Tokens only — green --accent for CTAs,
     --bg-card surface, --shadow elevation, 12px radius (softer than
     the launcher row below). Mobile-first; flex-wraps under 380px.
     ============================================================ */
  #wh-coach-cards{display:flex;flex-direction:column;gap:10px;margin:14px 0 8px;}
  #wh-coach-cards[hidden]{display:none !important;}

  .coach-card{
    display:flex;align-items:flex-start;gap:12px;
    background:var(--bg-card);border:1px solid var(--line-color);
    border-left:3px solid var(--accent);border-radius:12px;
    padding:14px 14px 14px 12px;
    box-shadow:var(--shadow);
    position:relative;
  }
  .coach-card-icon{
    flex-shrink:0;width:38px;height:38px;display:flex;align-items:center;justify-content:center;
    background:rgba(var(--accent-rgb),0.10);border-radius:10px;color:var(--accent);
  }
  .coach-card-icon svg{width:22px;height:22px;}
  .coach-card-body{flex:1;min-width:0;padding-right:24px;}
  .coach-card-title{
    font-size:var(--fs-base);font-weight:600;color:var(--text-primary);
    line-height:1.25;letter-spacing:-0.01em;margin-bottom:3px;
  }
  .coach-card-promise{
    font-size:var(--fs-sm);color:var(--text-secondary);line-height:1.4;
  }
  .coach-card-cta{
    flex-shrink:0;align-self:center;
    background:var(--accent);color:#fff;border:0;border-radius:8px;
    padding:8px 12px;font-family:inherit;font-size:var(--fs-sm);font-weight:600;
    cursor:pointer;letter-spacing:-0.005em;
    -webkit-tap-highlight-color:transparent;
    transition:background 0.12s, transform 0.08s;
  }
  .coach-card-cta:hover{background:var(--accent-hover);}
  .coach-card-cta:active{transform:scale(0.97);}
  .coach-card-dismiss{
    position:absolute;top:6px;right:8px;
    width:24px;height:24px;display:flex;align-items:center;justify-content:center;
    background:transparent;border:0;color:var(--text-muted);
    font-size:18px;line-height:1;cursor:pointer;font-family:inherit;
    border-radius:6px;-webkit-tap-highlight-color:transparent;
    transition:background 0.12s, color 0.12s;
  }
  .coach-card-dismiss:hover{background:var(--bg-elevated);color:var(--text-primary);}

  @media (max-width:380px){
    .coach-card{flex-wrap:wrap;}
    .coach-card-body{flex:1 1 100%;padding-right:24px;}
    .coach-card-cta{margin-left:50px;margin-top:4px;}
  }

  .coach-seeds{
    background:var(--bg-elevated);border:1px dashed var(--line-strong);
    border-radius:10px;padding:10px 12px;display:flex;flex-wrap:wrap;gap:6px;
    align-items:center;
  }
  .coach-seeds-label{
    width:100%;font-size:var(--fs-xs);font-weight:600;color:var(--text-secondary);
    text-transform:uppercase;letter-spacing:.06em;margin-bottom:2px;
  }
  .coach-seed-chip{
    background:var(--bg-card);border:1px solid var(--line-color);
    border-radius:999px;padding:6px 12px;font-family:inherit;
    font-size:var(--fs-sm);color:var(--text-primary);
    cursor:pointer;-webkit-tap-highlight-color:transparent;
    transition:background 0.12s, border-color 0.12s;
  }
  .coach-seed-chip:hover{background:var(--card-hover-bg);border-color:var(--accent);}
  .coach-seed-chip:active{background:rgba(var(--accent-rgb),0.10);}

  /* ============================================================
     RECORDING PILL — global voice-note status banner (2026-05-29)
     Floating top-fixed amber banner shown for the entire duration of an
     audio-note recording. Sits at z-index above everything so the user
     can stop from any section / modal. Survives navTo() because it's
     in <body>, not inside #mainContent. Stop button is the same toggle
     entry-point (triggerHeroAudioNote — idempotent: stops if recording).
     Stays on-palette via --amber (#F59E0B per CLAUDE.md Design System).
  ============================================================ */
  #recordingPill{
    position:fixed;
    /* 2026-05-29 (PM): bumped from 8px → 110px to clear iOS Chrome's URL bar
       AND the "Microphone access allowed" permission banner that appears
       below it for ~3-5s after mic grant. The env(safe-area-inset-top) on
       iOS Chrome reflects the notch, not the URL bar — so we need static
       headroom on top. PWA standalone mode will just see the pill ~110px
       lower than before, still comfortably in the visible viewport above
       any content. */
    top:calc(110px + env(safe-area-inset-top,0px));
    left:50%;transform:translateX(-50%);
    z-index:99999;
    display:flex;align-items:center;gap:10px;
    padding:8px 8px 8px 14px;
    background:#0D1B2A;
    border:1.5px solid #F59E0B;
    border-radius:999px;
    box-shadow:0 6px 22px rgba(0,0,0,0.32);
    color:#f1f5f9;
    font-family:Inter,system-ui,-apple-system,sans-serif;
    font-size:var(--fs-sm);
    letter-spacing:-0.01em;
    animation:recPillIn .25s cubic-bezier(.34,1.06,.64,1);
    max-width:calc(100vw - 24px);
  }
  #recordingPill[hidden]{display:none;}
  #recordingPill .rec-dot{
    width:9px;height:9px;border-radius:50%;
    background:#F59E0B;
    box-shadow:0 0 0 0 rgba(245,158,11,0.55);
    animation:recDotPulse 1.1s ease-out infinite;
    flex-shrink:0;
  }
  #recordingPill .rec-label{
    color:#F59E0B;font-weight:700;
    text-transform:uppercase;letter-spacing:0.08em;
    font-size:0.72rem;
    flex-shrink:0;
  }
  #recordingPill .rec-timer{
    color:#f1f5f9;font-weight:600;
    font-variant-numeric:tabular-nums;
    font-feature-settings:"tnum";
    min-width:38px;text-align:left;
    flex-shrink:0;
  }
  #recordingPill .rec-stop{
    display:flex;align-items:center;gap:6px;
    min-height:36px;padding:6px 14px 6px 12px;
    background:#F59E0B;color:#0D1B2A;
    border:none;border-radius:999px;
    font-family:inherit;font-size:var(--fs-sm);font-weight:700;letter-spacing:-0.01em;
    cursor:pointer;-webkit-tap-highlight-color:transparent;touch-action:manipulation;
    transition:background .15s,transform .1s;
    margin-left:4px;
  }
  #recordingPill .rec-stop:hover{background:#fbbf24;}
  #recordingPill .rec-stop:active{transform:scale(0.96);}
  #recordingPill .rec-stop:focus-visible{outline:2px solid #f1f5f9;outline-offset:2px;}
  #recordingPill .rec-stop svg{flex-shrink:0;}

  @keyframes recPillIn {
    from { opacity:0; transform:translate(-50%, -8px); }
    to   { opacity:1; transform:translate(-50%, 0); }
  }
  @keyframes recDotPulse {
    0%   { box-shadow:0 0 0 0 rgba(245,158,11,0.55); opacity:1; }
    70%  { box-shadow:0 0 0 8px rgba(245,158,11,0); opacity:0.85; }
    100% { box-shadow:0 0 0 0 rgba(245,158,11,0); opacity:1; }
  }
  @media (max-width: 360px) {
    #recordingPill{ font-size:0.78rem; padding:7px 7px 7px 12px; gap:8px; }
    #recordingPill .rec-stop{ padding:5px 12px 5px 10px; min-height:32px; }
  }

  /* ============================================================
     SPORTING EVENTS V1 (2026-06-02). Uses project design tokens
     (--bg-card, --text-primary, --line-color, --accent, etc.) so
     light/dark themes flip automatically via tokens.css's
     html[data-theme="dark"] block. Hotfix 2026-06-01 PM: original
     pass used non-existent --text / --muted / --bg-elev tokens —
     fallbacks fired in BOTH themes, leaving dark text on dark bg.
     ============================================================ */
  .sports-settings .settings-row-btn{
    min-height:36px;padding:6px 14px;
    background:var(--accent);color:#fff;
    border:none;border-radius:6px;
    font-family:inherit;font-size:var(--fs-sm);font-weight:600;
    cursor:pointer;-webkit-tap-highlight-color:transparent;
    transition:background .15s, transform .1s;
  }
  .sports-settings .settings-row-btn:hover{ filter:brightness(1.06); }
  .sports-settings .settings-row-btn:active{ transform:scale(0.97); }
  .sports-settings .settings-row-btn.is-active{
    background:transparent;color:var(--text-primary);
    border:1px solid var(--line-color);
  }

  /* Calendar day-cell soccer-ball badge — Day-5 checkered icon.
     Position: top-LEFT of month cells; bottom-left of week column headers.
     Color follows the theme's --text-secondary token so it stays legible
     on both light and dark backgrounds (no media query needed). */
  .cal-day-sports-ball{
    display:inline-flex;align-items:center;justify-content:center;
    width:14px;height:14px;
    color:var(--text-secondary);
    position:absolute;top:3px;left:3px;
    pointer-events:none;
    z-index:2;
  }
  .cal-day-sports-ball svg .csb-ring{
    fill:none;stroke:currentColor;stroke-width:1.6;
  }
  .cal-day-sports-ball svg .csb-pent{
    fill:none;stroke:currentColor;stroke-width:1.2;stroke-linejoin:round;
  }
  .cal-day-sports-ball svg .csb-spoke{
    stroke:currentColor;stroke-width:1.0;stroke-linecap:round;
  }
  .cal-day-sports-ball.is-fav{
    color:var(--accent);
  }
  .cal-day-sports-ball.is-fav svg .csb-ring{ stroke-width:1.9; }
  .cal-day-sports-ball.is-fav svg .csb-pent{ fill:currentColor; }
  .cal-day-sports-ball.is-fav svg .csb-spoke{ stroke-width:1.4; }

  /* Week-view variant — bottom-left of column header so it doesn't clash
     with the date number that lives top-right. */
  .cal-week-col .cal-day-sports-ball{
    top:auto;bottom:4px;left:4px;right:auto;
  }

  /* Day-sheet sports card — tinted, no left bar (read-only data, visually
     distinct from user events which have the colored left bar). Sits ABOVE
     the user-events list per PRD §6.C, separated by .sports-day-divider. */
  .sports-day-card{
    margin:0 0 14px;padding:12px 14px;
    background:rgba(var(--accent-rgb),0.08);
    border:1px solid var(--line-accent);
    border-radius:8px;
  }
  .sports-day-card-header{
    display:flex;justify-content:space-between;align-items:center;
    margin-bottom:10px;padding-bottom:8px;
    border-bottom:1px solid var(--line-accent);
  }
  .sports-day-card-title-wrap{
    display:inline-flex;align-items:center;gap:8px;
  }
  .sports-day-card-icon{
    color:var(--accent);flex-shrink:0;
  }
  .sports-day-card-icon .csb-ring{  fill:none;stroke:currentColor;stroke-width:1.6; }
  .sports-day-card-icon .csb-pent{  fill:currentColor;stroke:currentColor;stroke-width:1.0;stroke-linejoin:round; }
  .sports-day-card-icon .csb-spoke{ stroke:currentColor;stroke-width:1.2;stroke-linecap:round; }
  .sports-day-card-title{
    font-weight:700;font-size:0.95rem;
    color:var(--text-primary);letter-spacing:-0.01em;
  }
  .sports-day-card-count{
    font-size:0.75rem;color:var(--accent);font-weight:600;
  }
  .sports-day-match{
    padding:8px 0;
  }
  .sports-day-match + .sports-day-match{
    border-top:1px solid var(--line-accent);
  }
  .sports-day-match .smatch-row{
    display:grid;grid-template-columns:auto 1fr auto;gap:10px;align-items:center;
    font-size:0.9rem;
  }
  .sports-day-match .smatch-time{
    font-variant-numeric:tabular-nums;font-weight:700;color:var(--text-primary);
    min-width:46px;font-size:0.9rem;
  }
  .sports-day-match .smatch-teams{
    color:var(--text-primary);font-weight:500;
    display:flex;align-items:center;gap:6px;flex-wrap:wrap;
  }
  .sports-day-match .smatch-vs{
    color:var(--text-muted);font-weight:500;font-size:0.8rem;
  }
  .sports-day-match .smatch-meta{
    font-size:0.74rem;color:var(--text-secondary);
    margin-top:3px;padding-left:56px;letter-spacing:0.01em;
  }
  .sports-day-match.is-fav .smatch-teams{
    color:var(--accent);font-weight:700;
  }
  .sports-day-match.is-fav .smatch-time{
    color:var(--accent);
  }
  /* Share-only action bar — read-only sports rows show ONLY Share (per PRD §6.C).
     No Edit/Attach/Erase; user can't modify FIFA data. */
  .sports-day-match .smatch-share{
    display:inline-flex;align-items:center;justify-content:center;
    width:34px;height:34px;
    background:transparent;border:1px solid var(--line-accent);
    border-radius:6px;color:var(--accent);cursor:pointer;
    -webkit-tap-highlight-color:transparent;
    transition:background .12s, transform .08s;flex-shrink:0;
  }
  .sports-day-match .smatch-share:hover{ background:rgba(var(--accent-rgb),0.10); }
  .sports-day-match .smatch-share:active{ transform:scale(0.94); }

  /* "Other games" accordion (2026-06-02). Used inside .sports-day-card AFTER
     the favorite-team matches when both favorites + non-favorites exist on
     the same day. <details> + <summary> for zero-JS open/close. The native
     disclosure marker is hidden and replaced with our own chevron so the
     summary row visually mirrors the match-row affordance above. */
  .sports-day-others{
    margin-top:6px;border-top:1px solid var(--line-accent);
  }
  .sports-day-others > summary{
    list-style:none;cursor:pointer;
    padding:10px 4px 10px 56px;
    display:flex;align-items:center;justify-content:space-between;gap:10px;
    color:var(--text-secondary);font-size:0.85rem;font-weight:600;letter-spacing:0.01em;
    -webkit-tap-highlight-color:transparent;
    position:relative;
  }
  .sports-day-others > summary::-webkit-details-marker{ display:none; }
  /* Chevron — sits in the time-column gutter (left-aligned, 0-46px), points
     right when closed, rotates 90° when open. */
  .sports-day-others > summary::before{
    content:"";
    position:absolute;left:18px;top:50%;
    width:8px;height:8px;
    border-right:2px solid var(--text-muted);
    border-bottom:2px solid var(--text-muted);
    transform:translateY(-65%) rotate(-45deg);
    transition:transform .15s;
  }
  .sports-day-others[open] > summary::before{
    transform:translateY(-35%) rotate(45deg);
  }
  .sports-day-others > summary .sdo-count{
    color:var(--text-muted);font-weight:500;
    font-variant-numeric:tabular-nums;
    background:rgba(var(--accent-rgb),0.08);
    border-radius:10px;padding:2px 9px;font-size:0.78rem;
  }
  .sports-day-others > summary:hover{ color:var(--text-primary); }
  .sports-day-others > summary:active{ background:rgba(var(--accent-rgb),0.05); }
  /* When expanded, the row container inside .sdo-body uses the same row
     separators as the favorites above — keep the visual rhythm consistent. */
  .sports-day-others .sdo-body .sports-day-match:first-child{
    border-top:1px solid var(--line-accent);
  }

  /* ── Day-10 (2026-06-02) — Status badge + blurred score chip ───────────── */
  /* Status badge — "LIVE" / "FT". Communicates life-state of the match without
     exposing the score. Safe for spoiler-averse users. The LIVE variant pulses
     subtly so the eye knows the match is happening NOW. */
  .smatch-status-badge{
    display:inline-flex;align-items:center;justify-content:center;
    font-size:0.65rem;font-weight:800;letter-spacing:0.08em;
    padding:1px 6px;border-radius:3px;
    background:rgba(var(--text-muted-rgb,148,163,184),0.18);
    color:var(--text-secondary);
    vertical-align:1px;
    font-variant-numeric:tabular-nums;
  }
  .smatch-status-badge.ssb-in-play{
    background:rgba(245,158,11,0.18);color:#b45309;
    animation:smatch-live-pulse 1.6s ease-in-out infinite;
  }
  .smatch-status-badge.ssb-finished{
    background:rgba(var(--accent-rgb),0.10);color:var(--accent);
  }
  @keyframes smatch-live-pulse{
    0%, 100% { opacity:1;     }
    50%      { opacity:0.55;  }
  }
  /* Blurred score chip. Score numerals live inside .ssc-score and are
     filter-blurred until the user taps. .ssc-overlay sits on top showing an
     eye-slash icon when blurred so the affordance is unambiguous. */
  .smatch-score-chip{
    position:relative;display:inline-flex;align-items:center;justify-content:center;
    min-width:48px;min-height:22px;
    padding:1px 8px;border-radius:4px;
    background:rgba(var(--accent-rgb),0.10);
    border:1px solid var(--line-accent);
    color:var(--text-primary);font-weight:700;font-size:0.78rem;
    font-variant-numeric:tabular-nums;
    cursor:pointer;-webkit-tap-highlight-color:transparent;
    vertical-align:1px;line-height:1;
    transition:background .12s, transform .08s;
  }
  .smatch-score-chip:hover{ background:rgba(var(--accent-rgb),0.16); }
  .smatch-score-chip:active{ transform:scale(0.96); }
  .smatch-score-chip .ssc-score{
    transition:filter .18s, color .18s;
  }
  .smatch-score-chip[data-revealed="false"] .ssc-score{
    filter:blur(6px);color:var(--text-secondary);
  }
  .smatch-score-chip .ssc-overlay{
    position:absolute;inset:0;
    display:none;align-items:center;justify-content:center;
    color:var(--text-muted);pointer-events:none;
  }
  .smatch-score-chip[data-revealed="false"] .ssc-overlay{ display:flex; }

  /* ── Day-11 (2026-06-02) — World-rank chip + reference line ─────────── */
  /* Small "#N" chip rendered immediately after each team name. The chip
     ranks the team in FIFA's world standing (frozen at tournament start;
     refresh manually if FIFA publishes new rankings during the tournament). */
  .smatch-rank{
    display:inline-flex;align-items:center;justify-content:center;
    font-size:0.65rem;font-weight:700;letter-spacing:0.02em;
    color:var(--text-muted);
    padding:0 4px;margin-left:4px;
    border-radius:3px;
    background:rgba(var(--text-muted-rgb,148,163,184),0.12);
    vertical-align:1px;font-variant-numeric:tabular-nums;
  }
  .sports-day-match.is-fav .smatch-rank{
    color:var(--accent);background:rgba(var(--accent-rgb),0.10);
  }
  /* Reference line — capacity · weather · broadcaster. Below the meta line
     (Group H · Los Angeles), this carries the discoverable extras. The line
     hides itself when all three segments are empty (graceful degradation
     while broadcaster/weather data races to load on first session). */
  .smatch-refs{
    padding-left:56px;          /* align under the team-name column, not under the time */
    margin-top:2px;
    font-size:0.72rem;color:var(--text-muted);
    display:flex;flex-wrap:wrap;align-items:center;gap:6px;
    line-height:1.35;
  }
  .smatch-ref{
    display:inline-flex;align-items:center;
    color:var(--text-secondary);
  }
  .smref-sep{
    color:var(--text-muted);font-weight:400;opacity:0.6;
  }
  .smref-bc{
    color:var(--accent);font-weight:600;
  }

  /* ── Day-10 (2026-06-02) — Spoiler-guard picker (bottom-sheet) ───────── */
  /* Three radio rows: Ask / Show / Blur. Mirrors the favorite-teams flag
     picker layout; each tap commits + closes the sheet (no Save step). */
  .sgp-overlay{
    position:fixed;inset:0;z-index:6500;
    background:rgba(0,0,0,0.45);
    display:none;align-items:flex-end;justify-content:center;
    -webkit-tap-highlight-color:transparent;
  }
  .sgp-overlay.is-open{ display:flex; }
  .sgp-sheet{
    width:100%;max-width:520px;
    background:var(--bg-card);color:var(--text-primary);
    border-radius:14px 14px 0 0;
    padding:18px 16px calc(20px + env(safe-area-inset-bottom)) 16px;
    box-shadow:0 -8px 30px rgba(0,0,0,0.18);
    animation:sgp-slide-up .22s ease-out;
  }
  @keyframes sgp-slide-up{
    from{ transform:translateY(20px); opacity:0.6; }
    to  { transform:translateY(0);    opacity:1;   }
  }
  .sgp-header{
    display:flex;align-items:center;justify-content:space-between;
    padding-bottom:12px;border-bottom:1px solid var(--line-accent);
  }
  .sgp-title-line{
    font-weight:700;font-size:1.0rem;color:var(--text-primary);
  }
  .sgp-close{
    background:transparent;border:none;cursor:pointer;
    color:var(--text-muted);font-size:1.5rem;line-height:1;
    padding:4px 8px;border-radius:6px;
  }
  .sgp-close:hover{ color:var(--text-primary); background:rgba(var(--accent-rgb),0.08); }
  .sgp-body{ padding-top:8px; }
  .sgp-option{
    display:flex;align-items:flex-start;gap:12px;
    width:100%;text-align:left;
    background:transparent;border:none;cursor:pointer;
    padding:14px 8px;border-radius:8px;
    -webkit-tap-highlight-color:transparent;color:var(--text-primary);
  }
  .sgp-option:hover{ background:rgba(var(--accent-rgb),0.06); }
  .sgp-option:active{ background:rgba(var(--accent-rgb),0.12); }
  .sgp-option + .sgp-option{ margin-top:2px; }
  .sgp-radio{
    flex-shrink:0;width:20px;height:20px;border-radius:50%;
    border:2px solid var(--text-muted);
    margin-top:2px;position:relative;
  }
  .sgp-option.is-active .sgp-radio{ border-color:var(--accent); }
  .sgp-option.is-active .sgp-radio::after{
    content:"";position:absolute;inset:3px;border-radius:50%;
    background:var(--accent);
  }
  .sgp-text{ display:flex;flex-direction:column;gap:2px;flex:1;min-width:0; }
  .sgp-title{ font-weight:600;font-size:0.95rem;color:var(--text-primary); }
  .sgp-sub{   font-size:0.8rem;color:var(--text-secondary); }

  /* Hairline separator between the sports block and the user-events block.
     The "— your events —" caption sits inside a centered gap so the divide
     is unambiguous. */
  .sports-day-divider{
    display:flex;align-items:center;gap:12px;
    margin:6px 0 16px;
    color:var(--text-muted);
    font-size:0.72rem;letter-spacing:0.05em;text-transform:uppercase;
  }
  .sports-day-divider::before,
  .sports-day-divider::after{
    content:'';flex:1;height:1px;background:var(--line-color);
  }
  .sports-day-divider span{
    padding:0 4px;white-space:nowrap;
  }

  /* Sports V1 — pre-tournament Coach Card on Dashboard.
     Lives in #sports-coach-card-host; rendered by _sportsRenderCoachCard().
     WHITE card with green accent stripe + border. Initial Day-5 build used
     rgba(green,0.08) fill which rendered nearly invisible over the dark navy
     dashboard background. Matches the upload-card visual language for legibility. */
  #sports-coach-card-host{ margin:0 0 14px; }
  .sports-coach-card{
    display:grid;
    grid-template-columns:auto 1fr auto auto;
    align-items:center;gap:12px;
    padding:14px 14px 14px 16px;
    background:var(--bg-card);
    border:1px solid var(--line-accent);
    border-left:4px solid var(--accent);
    border-radius:10px;
    position:relative;
    box-shadow:var(--shadow);
  }
  .sports-coach-icon{
    width:38px;height:38px;flex-shrink:0;
    display:inline-flex;align-items:center;justify-content:center;
    background:rgba(var(--accent-rgb),0.10);
    border:1px solid var(--line-accent);
    border-radius:50%;
    color:var(--accent);
  }
  .sports-coach-icon-svg .csb-ring{  fill:none;stroke:currentColor;stroke-width:1.6; }
  .sports-coach-icon-svg .csb-pent{  fill:currentColor;stroke:currentColor;stroke-width:1.0;stroke-linejoin:round; }
  .sports-coach-icon-svg .csb-spoke{ stroke:currentColor;stroke-width:1.2;stroke-linecap:round; }
  .sports-coach-body{ min-width:0; }
  .sports-coach-kicker{
    font-size:0.7rem;letter-spacing:0.06em;text-transform:uppercase;
    color:var(--accent);font-weight:700;margin-bottom:2px;
  }
  .sports-coach-title{
    font-size:0.95rem;font-weight:700;color:var(--text-primary);
    letter-spacing:-0.01em;line-height:1.25;
  }
  .sports-coach-promise{
    font-size:0.78rem;color:var(--text-secondary);margin-top:2px;
    overflow:hidden;text-overflow:ellipsis;
    display:-webkit-box;-webkit-line-clamp:2;line-clamp:2;-webkit-box-orient:vertical;
  }
  .sports-coach-cta{
    min-height:36px;padding:6px 16px;
    background:var(--accent);color:#fff;
    border:none;border-radius:6px;
    font-family:inherit;font-size:0.85rem;font-weight:700;
    cursor:pointer;-webkit-tap-highlight-color:transparent;
    transition:background .12s, transform .08s;
    flex-shrink:0;
  }
  .sports-coach-cta:hover{ background:var(--accent-hover); }
  .sports-coach-cta:active{ transform:scale(0.96); }
  .sports-coach-dismiss{
    width:24px;height:24px;
    display:inline-flex;align-items:center;justify-content:center;
    background:transparent;border:none;
    color:var(--text-muted);
    cursor:pointer;-webkit-tap-highlight-color:transparent;
    border-radius:4px;transition:background .12s, color .12s;
    flex-shrink:0;
  }
  .sports-coach-dismiss:hover{ background:var(--bg-elevated);color:var(--text-primary); }
  @media (max-width: 380px){
    .sports-coach-card{
      grid-template-columns:auto 1fr auto;
      grid-template-rows:auto auto;
      row-gap:8px;
    }
    .sports-coach-cta{ grid-column:1 / -1; }
  }

  /* Sports search results — small checkered ball replaces the colored dot
     in .csr-dot slot. Fav-team rows tint accent green; non-fav stay slate. */
  .csr-sports-dot{
    display:inline-flex;align-items:center;justify-content:center;
    width:14px;height:14px;flex-shrink:0;
    color:var(--text-secondary);
  }
  .csr-sports-dot.is-fav{ color:var(--accent); }
  .csr-sports-dot svg .csb-ring{  fill:none;stroke:currentColor;stroke-width:1.6; }
  .csr-sports-dot svg .csb-pent{  fill:none;stroke:currentColor;stroke-width:1.0;stroke-linejoin:round; }
  .csr-sports-dot svg .csb-spoke{ stroke:currentColor;stroke-width:0.9;stroke-linecap:round; }
  .csr-sports-dot.is-fav svg .csb-pent{ fill:currentColor; }

  .calsearch-result.is-sports .csr-title{ font-weight:600; }
  .calsearch-result.is-sports.is-fav .csr-title{ color:var(--accent); }
  .csr-tag-sports{
    background:rgba(var(--accent-rgb),0.10);
    border-color:var(--line-accent);
    color:var(--accent);
  }

  /* Non-entitled teaser card — sits at the top of search results. Tapping
     opens the opt-in modal. Visually distinct from regular result rows. */
  .calsearch-sports-teaser{
    display:grid;
    grid-template-columns:auto 1fr auto;align-items:center;gap:12px;
    margin:10px 14px 8px;padding:12px 14px;
    background:var(--bg-card);
    border:1px solid var(--line-accent);
    border-left:4px solid var(--accent);
    border-radius:10px;
    cursor:pointer;-webkit-tap-highlight-color:transparent;
    transition:background .12s, transform .08s;
    box-shadow:var(--shadow);
  }
  .calsearch-sports-teaser:hover{ background:var(--card-hover-bg); }
  .calsearch-sports-teaser:active{ transform:scale(0.99); }
  .calsearch-sports-teaser .cst-icon{
    width:36px;height:36px;flex-shrink:0;
    display:inline-flex;align-items:center;justify-content:center;
    background:rgba(var(--accent-rgb),0.10);
    border:1px solid var(--line-accent);
    border-radius:50%;
    color:var(--accent);
  }
  .calsearch-sports-teaser .cst-kicker{
    font-size:0.66rem;letter-spacing:0.06em;text-transform:uppercase;
    color:var(--accent);font-weight:700;margin-bottom:1px;
  }
  .calsearch-sports-teaser .cst-title{
    font-size:0.92rem;font-weight:700;color:var(--text-primary);
    letter-spacing:-0.01em;line-height:1.2;
  }
  .calsearch-sports-teaser .cst-meta{
    font-size:0.72rem;color:var(--text-secondary);margin-top:1px;
    overflow:hidden;text-overflow:ellipsis;
    display:-webkit-box;-webkit-line-clamp:2;line-clamp:2;-webkit-box-orient:vertical;
  }
  .calsearch-sports-teaser .cst-cta{
    min-height:32px;padding:5px 14px;
    background:var(--accent);color:#fff;border:none;border-radius:6px;
    font-family:inherit;font-size:0.78rem;font-weight:700;
    cursor:pointer;-webkit-tap-highlight-color:transparent;flex-shrink:0;
    transition:background .12s, transform .08s;
  }
  .calsearch-sports-teaser .cst-cta:hover{ background:var(--accent-hover); }

  /* Sports V1 — chat result list (sectioned: Live / Upcoming / Recent).
     Rendered inside .msg.assistant .msg-bubble after a query_sports_matches
     tool result lands. Tapping a row opens that day in the calendar. */
  .wh-sports-results{
    display:flex;flex-direction:column;gap:14px;
    margin:6px 0 2px;
  }
  .wh-sports-section{ display:flex;flex-direction:column;gap:6px; }
  .wh-sports-section-header{
    font-size:0.66rem;letter-spacing:0.07em;text-transform:uppercase;
    color:var(--text-secondary);font-weight:700;padding:0 2px;
  }
  .wh-sports-section--live .wh-sports-section-header{
    color:#dc2626;
  }
  .wh-sports-row{
    display:grid;grid-template-columns:auto 1fr auto;gap:10px;align-items:center;
    width:100%;text-align:left;
    background:var(--bg-card);
    border:1px solid var(--line-color);
    border-radius:8px;padding:10px 12px;
    cursor:pointer;-webkit-tap-highlight-color:transparent;
    font-family:inherit;transition:background .12s, border-color .12s, transform .08s;
  }
  .wh-sports-row:hover{ background:var(--card-hover-bg);border-color:var(--line-accent); }
  .wh-sports-row:active{ transform:scale(0.99); }
  .wh-sports-row.is-fav{
    border-color:var(--line-accent);
    background:rgba(var(--accent-rgb),0.06);
  }
  .wh-sports-row-icon{
    color:var(--text-secondary);flex-shrink:0;
    display:inline-flex;align-items:center;justify-content:center;
  }
  .wh-sports-row.is-fav .wh-sports-row-icon{ color:var(--accent); }
  .wh-sports-row-icon svg .csb-ring{  fill:none;stroke:currentColor;stroke-width:1.6; }
  .wh-sports-row-icon svg .csb-pent{  fill:none;stroke:currentColor;stroke-width:1.0;stroke-linejoin:round; }
  .wh-sports-row-icon svg .csb-spoke{ stroke:currentColor;stroke-width:0.9;stroke-linecap:round; }
  .wh-sports-row.is-fav .wh-sports-row-icon svg .csb-pent{ fill:currentColor; }
  .wh-sports-row-body{ min-width:0;overflow:hidden; }
  .wh-sports-row-title{
    font-size:0.9rem;font-weight:600;color:var(--text-primary);
    line-height:1.25;
    white-space:nowrap;overflow:hidden;text-overflow:ellipsis;
  }
  .wh-sports-row.is-fav .wh-sports-row-title{ color:var(--accent); }
  .wh-sports-row-vs{
    color:var(--text-muted);font-size:0.8rem;font-weight:500;
  }
  .wh-sports-row-score{
    color:var(--text-primary);font-size:0.95rem;font-weight:700;margin-left:4px;
  }
  /* Day 13.1 fix — chat-card score on its own line, not inline with title
     (which was getting clipped by white-space:nowrap + text-overflow:ellipsis). */
  .wh-sports-row-score-badge{
    display:flex;align-items:center;gap:6px;
    margin-top:4px;
  }
  .wh-sports-row-score-num{
    display:inline-flex;align-items:center;justify-content:center;
    background:rgba(var(--accent-rgb),0.14);
    color:var(--text-primary);
    font-size:1.0rem;font-weight:800;
    font-variant-numeric:tabular-nums;
    padding:2px 10px;border-radius:4px;
    border:1px solid var(--line-accent);
  }
  .wh-sports-row.is-fav .wh-sports-row-score-num{
    background:rgba(var(--accent-rgb),0.22);
    color:var(--accent);
  }
  .wh-sports-row-meta{
    font-size:0.72rem;color:var(--text-secondary);margin-top:2px;
    white-space:nowrap;overflow:hidden;text-overflow:ellipsis;
  }
  /* Day 11.5 — _ref rendering on chat match cards. The card IS the answer
     for "who's broadcasting", "what's the weather", "how is X ranked" —
     the single-turn architecture means the model's text reply is written
     before the tool result lands, so the value must live on the card. */
  .wh-sports-row-rank{
    display:inline-flex;align-items:center;justify-content:center;
    font-size:0.62rem;font-weight:700;letter-spacing:0.02em;
    color:var(--text-muted);
    padding:0 4px;margin-left:4px;border-radius:3px;
    background:rgba(var(--text-muted-rgb,148,163,184),0.12);
    vertical-align:1px;font-variant-numeric:tabular-nums;
  }
  .wh-sports-row.is-fav .wh-sports-row-rank{
    color:var(--accent);background:rgba(var(--accent-rgb),0.10);
  }
  .wh-sports-row-refs{
    font-size:0.70rem;color:var(--text-muted);margin-top:3px;
    line-height:1.35;
    /* Wrap on long lines — broadcaster lists can have 6-7 channels in the
       US slice. Better to wrap than truncate. */
    white-space:normal;
    word-break:break-word;
  }
  .wh-sports-row-refs .wh-sports-row-refsep{
    color:var(--text-muted);opacity:0.5;margin:0 6px;
  }
  .wh-sports-row-arrow{
    color:var(--text-muted);font-size:1.1rem;flex-shrink:0;
  }

  /* Chat upsell card (non-entitled user asks a sports question) */
  .wh-sports-upsell{
    display:grid;grid-template-columns:auto 1fr auto;align-items:center;gap:12px;
    padding:12px 14px;
    background:var(--bg-card);
    border:1px solid var(--line-accent);
    border-left:4px solid var(--accent);
    border-radius:10px;
    cursor:pointer;-webkit-tap-highlight-color:transparent;
    transition:background .12s, transform .08s;
    box-shadow:var(--shadow);
  }
  .wh-sports-upsell:hover{ background:var(--card-hover-bg); }
  .wh-sports-upsell:active{ transform:scale(0.99); }
  .wh-sports-upsell-icon{
    width:36px;height:36px;flex-shrink:0;
    display:inline-flex;align-items:center;justify-content:center;
    background:rgba(var(--accent-rgb),0.10);
    border:1px solid var(--line-accent);
    border-radius:50%;
    color:var(--accent);
  }
  .wh-sports-upsell-kicker{
    font-size:0.66rem;letter-spacing:0.06em;text-transform:uppercase;
    color:var(--accent);font-weight:700;margin-bottom:1px;
  }
  .wh-sports-upsell-title{
    font-size:0.92rem;font-weight:700;color:var(--text-primary);
    letter-spacing:-0.01em;line-height:1.2;
  }
  .wh-sports-upsell-meta{
    font-size:0.72rem;color:var(--text-secondary);margin-top:1px;
  }
  .wh-sports-upsell-cta{
    min-height:32px;padding:5px 14px;
    background:var(--accent);color:#fff;border:none;border-radius:6px;
    font-family:inherit;font-size:0.78rem;font-weight:700;
    cursor:pointer;-webkit-tap-highlight-color:transparent;flex-shrink:0;
    transition:background .12s, transform .08s;
  }
  .wh-sports-upsell-cta:hover{ background:var(--accent-hover); }

  @media (max-width: 380px){
    .wh-sports-upsell{ grid-template-columns:auto 1fr auto;grid-template-rows:auto auto;row-gap:8px; }
    .wh-sports-upsell-cta{ grid-column:1 / -1; }
  }

  /* ── Phase 6.2 Plan accordion CTA buttons ────────────────────────── */
  .plan-cta-upgrade{ display:inline-flex; align-items:center; gap:4px; padding:7px 12px; background:var(--accent); color:#0D1B2A; border-radius:6px; font-size:.85rem; font-weight:700; letter-spacing:-.01em; text-decoration:none; white-space:nowrap; transition:opacity .15s; }
  .plan-cta-upgrade:hover{ opacity:.88; }
  .plan-cta-manage{ padding:7px 12px; background:transparent; border:1px solid var(--line-color); border-radius:6px; font-size:.82rem; font-weight:600; color:var(--text-secondary); font-family:Inter,sans-serif; letter-spacing:-.005em; cursor:pointer; transition:border-color .15s, color .15s; white-space:nowrap; }
  .plan-cta-manage:hover{ border-color:var(--text-secondary); color:var(--text-primary); }
  .plan-cta-manage:disabled{ opacity:.6; cursor:progress; }

  /* ── Devices Linked accordion (Phase B.4, 2026-06-04) ──────────────── */
  .device-accordion { display:block; }
  .device-accordion summary { list-style:none; cursor:pointer; }
  .device-accordion summary::-webkit-details-marker { display:none; }
  .device-accordion-summary { user-select:none; -webkit-user-select:none; }
  .device-accordion-chevron { width:18px; height:18px; color:var(--text-secondary); margin-left:8px; flex-shrink:0; transition:transform .2s ease; }
  .device-accordion[open] .device-accordion-chevron { transform:rotate(180deg); }
  .device-accordion-list { padding:0; }
  .device-accordion-list .device-chip { border-top:1px solid var(--line-color); }
  .device-accordion-list:empty + nothing { display:none; }
