/* ── RECIPE VAULT — FRESH MINT + CORAL THEME ─────────────────────────────────
   Palette: soft mint backgrounds · deep teal ink · coral accent · warm white
   Typefaces: Lora (display) + Inter (UI)
   Signature: bright, airy kitchen aesthetic — like a sunny morning cookbook
   ──────────────────────────────────────────────────────────────────────────── */

:root {
  --clr-paper:      #f2faf7;
  --clr-paper-mid:  #e0f2ea;
  --clr-paper-deep: #c8e6d8;
  --clr-ink:        #0e3528;
  --clr-ink-mid:    #1e5c42;
  --clr-muted:      #5a8a74;
  --clr-coral:      #e8623a;
  --clr-coral-lt:   #fde8e1;
  --clr-coral-dk:   #b8431e;
  --clr-mint:       #2a9d6f;
  --clr-mint-lt:    #d4f0e4;
  --clr-yellow:     #f4a620;
  --clr-yellow-lt:  #fef3d8;
  --clr-red:        #c0392b;
  --clr-red-lt:     #fae4e0;
  --clr-surface:    #ffffff;
  --clr-border:     rgba(14,53,40,0.09);
  --clr-border-mid: rgba(14,53,40,0.18);

  /* Map accent to coral throughout */
  --clr-saffron:    var(--clr-coral);
  --clr-saffron-lt: var(--clr-coral-lt);
  --clr-saffron-dk: var(--clr-coral-dk);

  --font-display: 'Lora', Georgia, serif;
  --font-ui:      'Inter', system-ui, sans-serif;

  --radius-sm: 8px;
  --radius-md: 14px;
  --radius-lg: 20px;
  --radius-xl: 28px;

  --sidebar-w:   220px;
  --detail-w:    380px;
  --nav-h:       64px;
  --header-h:    56px;

  --shadow-card: 0 2px 14px rgba(14,53,40,0.07);
  --shadow-lift: 0 6px 28px rgba(14,53,40,0.13);
}

@media (prefers-color-scheme: dark) {
  :root {
    --clr-paper:      #081f14;
    --clr-paper-mid:  #0f2e1e;
    --clr-paper-deep: #163d29;
    --clr-ink:        #d6f5e8;
    --clr-ink-mid:    #90c9ae;
    --clr-muted:      #5a8a74;
    --clr-coral:      #f07a56;
    --clr-coral-lt:   #2e1510;
    --clr-coral-dk:   #ffaa8a;
    --clr-surface:    #0c2419;
    --clr-border:     rgba(214,245,232,0.09);
    --clr-border-mid: rgba(214,245,232,0.17);
    --shadow-card:    0 2px 14px rgba(0,0,0,0.4);
  }
}

/* ── RESET ── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html,body{height:100%;overflow:hidden}
body{background:var(--clr-paper);color:var(--clr-ink);font-family:var(--font-ui);font-size:15px;line-height:1.5;-webkit-font-smoothing:antialiased}
button{cursor:pointer;font-family:var(--font-ui);border:none;background:none}
input,select,textarea{font-family:var(--font-ui)}
ul,ol{list-style:none}

/* ── SPLASH ── */
.splash{position:fixed;inset:0;z-index:999;background:var(--clr-ink);display:flex;align-items:center;justify-content:center;transition:opacity .5s,visibility .5s}
.splash.fade-out{opacity:0;visibility:hidden}
.splash-inner{text-align:center;color:var(--clr-paper)}
.splash-icon{font-size:64px;margin-bottom:14px}
.splash-title{font-family:var(--font-display);font-size:36px;font-weight:600;letter-spacing:-.5px}
.splash-sub{font-size:16px;color:var(--clr-muted);margin-top:6px;font-style:italic}

/* ── CLOUD PICKER ── */
.cloud-picker{position:fixed;inset:0;z-index:100;background:var(--clr-paper);display:flex;align-items:center;justify-content:center;padding:24px}
.cp-inner{max-width:440px;width:100%}
.cp-eyebrow{font-size:12px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--clr-coral);margin-bottom:10px}
.cp-heading{font-family:var(--font-display);font-size:28px;font-weight:600;line-height:1.2;margin-bottom:12px}
.cp-sub{font-size:14px;color:var(--clr-muted);margin-bottom:32px;line-height:1.7}
.cp-btn{width:100%;display:flex;align-items:center;gap:14px;padding:16px 20px;border-radius:var(--radius-md);background:var(--clr-surface);border:1px solid var(--clr-border-mid);font-size:15px;font-weight:500;color:var(--clr-ink);margin-bottom:12px;transition:box-shadow .15s,transform .1s}
.cp-btn:hover{box-shadow:var(--shadow-lift);transform:translateY(-1px)}
.cp-btn:active{transform:scale(.98)}
.hidden{display:none!important}

/* ── APP SHELL ── */
.app{position:fixed;inset:0;display:flex;flex-direction:row}

/* ── SIDEBAR ── */
.sidebar{width:var(--sidebar-w);flex-shrink:0;background:var(--clr-ink);display:flex;flex-direction:column;overflow:hidden}
.sidebar-brand{display:flex;align-items:center;gap:10px;padding:20px 18px 16px}
.sidebar-logo{font-size:24px}
.sidebar-title{font-family:var(--font-display);font-size:18px;font-weight:600;color:var(--clr-paper);letter-spacing:-.3px}
.sidebar-nav{flex:1;padding:8px 10px;display:flex;flex-direction:column;gap:2px}
.sn-item{display:flex;align-items:center;gap:10px;padding:10px 12px;border-radius:var(--radius-sm);font-size:14px;font-weight:500;color:rgba(255,255,255,.45);transition:all .15s;position:relative;text-align:left}
.sn-item:hover{background:rgba(255,255,255,.09);color:rgba(255,255,255,.85)}
.sn-item.active{background:rgba(232,98,58,.22);color:var(--clr-coral)}
.sn-icon{font-size:18px;flex-shrink:0}
.sn-badge{background:var(--clr-coral);color:#fff;font-size:10px;font-weight:700;min-width:18px;height:18px;border-radius:9px;display:flex;align-items:center;justify-content:center;padding:0 4px;margin-left:auto}
.sidebar-cloud{padding:16px 18px;border-top:1px solid rgba(255,255,255,.08);font-size:13px;color:rgba(255,255,255,.38);cursor:pointer;display:flex;align-items:center;gap:8px;transition:color .15s}
.sidebar-cloud:hover{color:rgba(255,255,255,.7)}

/* ── MAIN CONTENT ── */
.main-content{flex:1;min-width:0;display:flex;flex-direction:row;overflow:hidden;background:var(--clr-paper)}
.screen{flex:1;overflow-y:auto;overflow-x:hidden;-webkit-overflow-scrolling:touch;padding:24px 28px 40px;display:none}
.screen.active{display:block}

/* ── DETAIL PANEL ── */
.detail-panel{width:var(--detail-w);flex-shrink:0;background:var(--clr-surface);border-left:1px solid var(--clr-border);overflow-y:auto;position:relative;display:flex;flex-direction:column}
.detail-panel.hidden{display:none}
.detail-close{position:absolute;top:12px;right:12px;width:32px;height:32px;border-radius:50%;background:rgba(255,255,255,0.15);font-size:15px;display:flex;align-items:center;justify-content:center;z-index:10;color:#fff;border:1px solid rgba(255,255,255,0.25);cursor:pointer}
.detail-close:hover{background:rgba(255,255,255,0.28)}
.detail-hero-sm{position:relative}
.detail-hero-sm{background:var(--clr-ink);padding:28px 20px 24px;text-align:center}
.detail-emoji-lg{font-size:64px;margin-bottom:12px}
.detail-tags{display:flex;gap:6px;flex-wrap:wrap;justify-content:center;margin-bottom:10px}
.detail-name{font-family:var(--font-display);font-size:22px;font-weight:600;color:var(--clr-paper);line-height:1.2;margin-bottom:6px}
.detail-meta-row{font-size:13px;color:rgba(255,255,255,.45)}
.detail-body{padding:18px;flex:1}
.detail-section{margin-bottom:22px}
.detail-section-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px}
.detail-section-title{font-size:12px;font-weight:600;letter-spacing:.06em;text-transform:uppercase;color:var(--clr-muted)}
.per-serving-label{font-size:11px;font-weight:400;text-transform:none;letter-spacing:0}
.serving-control{display:flex;align-items:center;gap:8px}
.serving-btn{width:26px;height:26px;border-radius:50%;background:var(--clr-paper-mid);color:var(--clr-ink);font-size:17px;display:flex;align-items:center;justify-content:center;border:1px solid var(--clr-border-mid)}
.serving-count{font-size:13px;font-weight:500;color:var(--clr-ink);white-space:nowrap}
.ingredient-list{display:flex;flex-direction:column}
.ingredient-item{display:flex;align-items:baseline;gap:10px;padding:8px 0;border-bottom:1px solid var(--clr-border);font-size:14px}
.ingredient-item:last-child{border-bottom:none}
.ingredient-amount{font-weight:600;color:var(--clr-coral);min-width:60px;font-size:13px}
.nutrition-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:6px}
.nut-card{background:var(--clr-paper);border:1px solid var(--clr-border);border-radius:var(--radius-sm);padding:8px 6px;text-align:center}
.nut-val{font-size:16px;font-weight:600;color:var(--clr-ink)}
.nut-label{font-size:11px;color:var(--clr-muted);margin-top:1px}
.steps-list{display:flex;flex-direction:column;gap:12px;counter-reset:step}
.step-item{display:flex;gap:12px;font-size:14px;line-height:1.6;color:var(--clr-ink)}
.step-item::before{content:counter(step);counter-increment:step;flex-shrink:0;width:24px;height:24px;border-radius:50%;background:var(--clr-coral-lt);color:var(--clr-coral-dk);font-size:12px;font-weight:600;display:flex;align-items:center;justify-content:center;margin-top:2px}
.detail-actions{display:flex;flex-direction:column;gap:8px;margin-top:8px;padding-bottom:20px}

/* ── PAGE HEADERS ── */
.page-header{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:20px;gap:12px;flex-wrap:wrap}
.page-title{font-family:var(--font-display);font-size:28px;font-weight:600;color:var(--clr-ink);line-height:1.1}
.page-sub{font-size:14px;color:var(--clr-muted);margin-top:4px}
.page-header-actions{display:flex;align-items:center;gap:8px;flex-shrink:0;flex-wrap:wrap}

/* ── SEARCH BAR ── */
.search-filter-bar{margin-bottom:20px}
.search-box{display:flex;align-items:center;gap:10px;background:var(--clr-surface);border:1px solid var(--clr-border-mid);border-radius:var(--radius-xl);padding:0 16px;margin-bottom:12px;box-shadow:var(--shadow-card)}
.search-icon{font-size:16px;opacity:.5;flex-shrink:0}
.search-input{flex:1;padding:12px 0;font-size:15px;color:var(--clr-ink);background:transparent;border:none;outline:none}
.search-input::placeholder{color:var(--clr-muted)}
.search-clear{font-size:13px;color:var(--clr-muted);padding:4px;background:var(--clr-paper-mid);border-radius:50%;width:22px;height:22px;display:flex;align-items:center;justify-content:center}
.chip-row{display:flex;gap:6px;flex-wrap:wrap}
.chip{flex-shrink:0;padding:5px 16px;border-radius:20px;font-size:13px;font-weight:500;border:1px solid var(--clr-border-mid);color:var(--clr-muted);background:transparent;transition:all .15s;white-space:nowrap}
.chip-active,.chip:hover{background:var(--clr-ink);color:var(--clr-paper);border-color:var(--clr-ink)}

/* ── RECIPE GRID ── */
.recipe-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:14px}
.recipe-card{background:var(--clr-surface);border:1px solid var(--clr-border);border-radius:var(--radius-md);padding:16px;cursor:pointer;transition:box-shadow .15s,transform .12s;display:flex;align-items:center;gap:14px;box-shadow:var(--shadow-card)}
.recipe-card:hover{box-shadow:var(--shadow-lift);transform:translateY(-2px)}
.recipe-card:active{transform:scale(.98)}
.recipe-thumb{width:56px;height:56px;border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;font-size:30px;flex-shrink:0;background:var(--clr-coral-lt)}
.recipe-info{flex:1;min-width:0}
.recipe-name{font-family:var(--font-display);font-size:16px;font-weight:600;color:var(--clr-ink);margin-bottom:3px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.recipe-sub{font-size:13px;color:var(--clr-muted)}
.recipe-arrow{color:var(--clr-coral);font-size:18px;flex-shrink:0}

/* ── STATE CARDS ── */
.state-card{display:flex;flex-direction:column;align-items:center;text-align:center;padding:60px 32px;gap:10px}
.state-emoji{font-size:52px}
.state-title{font-family:var(--font-display);font-size:20px;font-weight:600}
.state-sub{font-size:14px;color:var(--clr-muted);line-height:1.6;max-width:300px}

/* ── SPINNER ── */
.spinner{width:34px;height:34px;border-radius:50%;border:3px solid var(--clr-border-mid);border-top-color:var(--clr-coral);animation:spin .8s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}
@media(prefers-reduced-motion:reduce){.spinner{animation:none;opacity:.5}}

/* ── COOK MODE ── */
.cook-overlay{position:fixed;inset:0;z-index:200;background:var(--clr-ink);display:flex;flex-direction:column}
.cook-overlay.hidden{display:none}
.cook-header{display:flex;align-items:center;justify-content:space-between;padding:16px 24px;border-bottom:1px solid rgba(255,255,255,.1)}
.back-btn-light{font-size:14px;font-weight:500;color:rgba(255,255,255,.55);padding:6px 0}
.back-btn-light:hover{color:#fff}
.cook-title{font-family:var(--font-display);font-size:18px;font-weight:600;color:var(--clr-paper);flex:1;text-align:center;padding:0 16px}
.icon-btn-light{font-size:13px;color:rgba(255,255,255,.55);padding:6px 10px;border:1px solid rgba(255,255,255,.15);border-radius:var(--radius-sm)}
.icon-btn-light:hover{color:#fff;border-color:rgba(255,255,255,.4)}
.cook-body{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:32px 24px;max-width:700px;margin:0 auto;width:100%}
.cook-progress{width:100%;margin-bottom:32px}
.progress-bar{height:4px;background:rgba(255,255,255,.15);border-radius:2px;overflow:hidden;margin-bottom:8px}
.progress-fill{height:100%;background:var(--clr-coral);border-radius:2px;transition:width .3s ease}
.progress-label{font-size:13px;color:rgba(255,255,255,.38)}
.cook-step-card{width:100%;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.1);border-radius:var(--radius-lg);padding:40px 36px;min-height:200px;display:flex;align-items:center;justify-content:center;margin-bottom:32px}
.cook-step-text{font-family:var(--font-display);font-size:20px;line-height:1.7;color:var(--clr-paper);text-align:center}
.cook-controls{display:flex;gap:14px;width:100%;max-width:480px}
.cook-nav-btn{flex:1;padding:15px;border-radius:var(--radius-md);background:rgba(255,255,255,.08);color:var(--clr-paper);font-size:15px;font-weight:600;border:1px solid rgba(255,255,255,.15);transition:background .15s}
.cook-nav-btn:hover{background:rgba(255,255,255,.15)}
.cook-nav-next{background:var(--clr-coral);border-color:var(--clr-coral);color:#fff}
.cook-nav-next:hover{background:var(--clr-coral-dk)}
.cook-voice-hint{margin-top:20px;font-size:13px;color:rgba(255,255,255,.32);display:none}

/* ── PLANNER ── */
.week-label{font-size:14px;font-weight:500;color:var(--clr-ink);padding:0 4px}
.planner-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:10px}
.day-card{background:var(--clr-surface);border-radius:var(--radius-md);border:1px solid var(--clr-border);overflow:hidden;display:flex;flex-direction:column;min-height:180px}
.day-header{padding:10px 12px;background:var(--clr-paper-mid);border-bottom:1px solid var(--clr-border)}
.day-name{font-size:12px;font-weight:600;letter-spacing:.04em;color:var(--clr-ink)}
.day-date{font-size:11px;color:var(--clr-muted);margin-top:1px}
.day-today .day-header{background:var(--clr-coral-lt)}
.day-today .day-name{color:var(--clr-coral-dk)}
.day-meals{flex:1;padding:6px 0}
.day-meal-item{display:flex;align-items:center;gap:6px;padding:5px 10px;font-size:12px;color:var(--clr-ink)}
.day-meal-emoji{font-size:16px;flex-shrink:0}
.day-meal-name{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.day-meal-remove{color:var(--clr-muted);font-size:14px;padding:2px 4px;opacity:.6}
.day-meal-remove:hover{opacity:1;color:var(--clr-red)}
.day-empty{padding:12px 10px;font-size:12px;color:var(--clr-muted);text-align:center}
.day-add-btn{width:100%;padding:8px 10px;font-size:12px;color:var(--clr-coral);font-weight:500;text-align:center;border-top:1px dashed var(--clr-border-mid)}
.day-add-btn:hover{background:var(--clr-coral-lt)}

/* ── SHOPPING LIST ── */
.shopping-list{display:flex;flex-direction:column;max-width:640px}
.shopping-item{display:flex;align-items:center;gap:14px;padding:13px 0;border-bottom:1px solid var(--clr-border);cursor:pointer}
.shopping-item:last-child{border-bottom:none}
.shopping-check{width:22px;height:22px;border-radius:50%;border:2px solid var(--clr-border-mid);flex-shrink:0;display:flex;align-items:center;justify-content:center;transition:all .15s}
.shopping-item.checked .shopping-check{background:var(--clr-coral);border-color:var(--clr-coral)}
.shopping-item.checked .shopping-check::after{content:'✓';color:#fff;font-size:13px;font-weight:700}
.shopping-item.checked .shopping-item-text{text-decoration:line-through;color:var(--clr-muted)}
.shopping-item-text{font-size:15px;color:var(--clr-ink);flex:1}
.shopping-item-recipe{font-size:12px;color:var(--clr-muted)}

/* ── IMPORT ── */
.import-card{background:var(--clr-surface);border:1px solid var(--clr-border);border-radius:var(--radius-lg);padding:24px;max-width:800px;box-shadow:var(--shadow-card)}
.import-input-row{display:flex;gap:10px;margin-bottom:16px}
.url-input{flex:1;padding:12px 16px;font-size:15px;background:var(--clr-paper);color:var(--clr-ink);border:1px solid var(--clr-border-mid);border-radius:var(--radius-md);outline:none}
.url-input:focus{border-color:var(--clr-coral)}
.preview-eyebrow{font-size:12px;font-weight:600;letter-spacing:.07em;text-transform:uppercase;color:var(--clr-coral);margin-bottom:16px;border-top:1px solid var(--clr-border);padding-top:16px}
.import-fields-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:12px;margin-bottom:14px}
.field-label{display:flex;flex-direction:column;gap:5px;font-size:13px;font-weight:500;color:var(--clr-muted)}
.field-hint{font-weight:400;opacity:.7}
.field-input{padding:10px 12px;font-size:14px;color:var(--clr-ink);background:var(--clr-paper);border:1px solid var(--clr-border-mid);border-radius:var(--radius-sm);outline:none;width:100%}
.field-input:focus{border-color:var(--clr-coral)}
.field-textarea{resize:vertical;line-height:1.5}
.import-actions{display:flex;gap:10px;margin-top:16px}
.error-card{padding:14px 16px;background:var(--clr-red-lt);border-radius:var(--radius-sm);font-size:14px;color:var(--clr-red)}
.import-preview{margin-top:4px}

/* ── SETTINGS ── */
.settings-layout{display:grid;grid-template-columns:1fr 1fr;gap:20px;max-width:900px}
.settings-layout>div[style*="grid-column"]{grid-column:1/-1}
.settings-col{display:flex;flex-direction:column;gap:20px}
.settings-group{background:var(--clr-surface);border-radius:var(--radius-md);border:1px solid var(--clr-border);overflow:hidden;box-shadow:var(--shadow-card)}
.settings-label{font-size:12px;font-weight:600;letter-spacing:.06em;text-transform:uppercase;color:var(--clr-muted);padding:14px 16px 6px}
.cloud-toggle-row{display:flex;border-bottom:1px solid var(--clr-border)}
.cloud-opt{flex:1;padding:14px 16px;font-size:14px;font-weight:500;color:var(--clr-muted);display:flex;align-items:center;justify-content:space-between;border-right:1px solid var(--clr-border);transition:background .15s}
.cloud-opt:last-child{border-right:none}
.cloud-opt.active{color:var(--clr-ink);background:var(--clr-coral-lt)}
.cloud-check::after{content:'';display:block;width:8px;height:8px;border-radius:50%;background:transparent;transition:background .15s}
.cloud-opt.active .cloud-check::after{background:var(--clr-coral)}
.settings-row{display:flex;align-items:center;justify-content:space-between;padding:13px 16px;border-bottom:1px solid var(--clr-border);gap:12px}
.settings-row:last-child{border-bottom:none}
.settings-row-label{font-size:15px;color:var(--clr-ink)}
.settings-row-value{font-size:14px;color:var(--clr-muted)}
.settings-input{width:160px;padding:6px 10px;font-size:14px;color:var(--clr-ink);background:var(--clr-paper-mid);border:1px solid var(--clr-border-mid);border-radius:var(--radius-sm);outline:none;text-align:right}
.settings-select{padding:6px 10px;font-size:14px;color:var(--clr-ink);background:var(--clr-paper-mid);border:1px solid var(--clr-border-mid);border-radius:var(--radius-sm);outline:none;max-width:200px}
.toggle{position:relative;display:inline-block;width:46px;height:26px;flex-shrink:0}
.toggle input{opacity:0;width:0;height:0}
.toggle-track{position:absolute;inset:0;background:var(--clr-paper-deep);border-radius:13px;transition:background .2s;cursor:pointer}
.toggle-track::after{content:'';position:absolute;left:3px;top:3px;width:20px;height:20px;border-radius:50%;background:white;transition:transform .2s;box-shadow:0 1px 4px rgba(0,0,0,.22)}
.toggle input:checked+.toggle-track{background:var(--clr-coral)}
.toggle input:checked+.toggle-track::after{transform:translateX(20px)}

/* ── BUTTONS ── */
.btn-primary{background:var(--clr-coral);color:#fff;border:none;border-radius:var(--radius-md);padding:12px 20px;font-size:14px;font-weight:600;transition:opacity .15s,transform .1s;display:inline-flex;align-items:center;justify-content:center;gap:8px}
.btn-primary:hover{opacity:.88}
.btn-primary:active{transform:scale(.98)}
.btn-ghost{background:transparent;color:var(--clr-ink);border:1px solid var(--clr-border-mid);border-radius:var(--radius-md);padding:12px 20px;font-size:14px;font-weight:500;display:inline-flex;align-items:center;justify-content:center;gap:8px;transition:background .15s}
.btn-ghost:hover{background:var(--clr-paper-mid)}
.btn-ghost-sm{background:transparent;color:var(--clr-ink);border:1px solid var(--clr-border-mid);border-radius:var(--radius-sm);padding:7px 14px;font-size:13px;font-weight:500;display:inline-flex;align-items:center;gap:6px;transition:background .15s}
.btn-ghost-sm:hover{background:var(--clr-paper-mid)}
.btn-primary-sm{background:var(--clr-coral);color:#fff;border:none;border-radius:var(--radius-sm);padding:7px 14px;font-size:13px;font-weight:600;display:inline-flex;align-items:center;gap:6px}
.btn-primary-sm:hover{opacity:.88}
.full-width{width:100%}

/* ── TAGS ── */
.tag{font-size:11px;font-weight:600;letter-spacing:.05em;text-transform:uppercase;padding:3px 10px;border-radius:20px}
.tag-cuisine{background:rgba(255,255,255,.14);color:rgba(255,255,255,.8)}
.tag-time{background:rgba(232,98,58,.28);color:#ffcab5}
.tag-other{background:rgba(255,255,255,.09);color:rgba(255,255,255,.58)}

/* ── MODALS ── */
.modal-overlay{position:fixed;inset:0;z-index:300;background:rgba(14,53,40,.5);display:flex;align-items:center;justify-content:center;padding:24px}
.modal-card{background:var(--clr-paper);border-radius:var(--radius-xl);padding:28px 24px;width:100%;max-width:440px;box-shadow:var(--shadow-lift)}
.modal-title{font-family:var(--font-display);font-size:20px;font-weight:600;margin-bottom:8px}
.modal-sub{font-size:14px;color:var(--clr-muted);margin-bottom:20px;line-height:1.6}
.day-picker{display:flex;flex-direction:column;gap:6px;max-height:340px;overflow-y:auto}
.day-pick-btn{width:100%;padding:11px 16px;border-radius:var(--radius-sm);background:var(--clr-surface);border:1px solid var(--clr-border);font-size:14px;color:var(--clr-ink);text-align:left;display:flex;justify-content:space-between;transition:background .12s}
.day-pick-btn:hover{background:var(--clr-coral-lt)}
.day-pick-count{font-size:13px;color:var(--clr-muted)}

/* ── MOBILE BOTTOM NAV ── */
.bottom-nav{display:none}

/* ── FOCUS ── */
:focus-visible{outline:2px solid var(--clr-coral);outline-offset:2px}

/* ════════════════════════════════════════════════════
   MOBILE  (≤ 768px)
   ════════════════════════════════════════════════════ */
@media(max-width:768px){
  .app{flex-direction:column}
  .sidebar{display:none}
  .main-content{flex-direction:column}
  .detail-panel{display:none!important}
  .screen{padding:12px 14px 80px}
  .recipe-grid{grid-template-columns:1fr;gap:1px}
  .recipe-card{border-radius:0;border:none;border-bottom:1px solid var(--clr-border);box-shadow:none;padding:13px 14px}
  .recipe-card:hover{transform:none;box-shadow:none}
  .planner-grid{grid-template-columns:1fr}
  .settings-layout{grid-template-columns:1fr}
  .import-fields-grid{grid-template-columns:1fr}
  .import-card{border:none;border-radius:0;box-shadow:none;padding:0}
  .import-input-row{flex-direction:column}
  .bottom-nav{display:flex;height:var(--nav-h);flex-shrink:0;background:var(--clr-ink);border-top:1px solid rgba(255,255,255,.08)}
  .nav-item{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;padding:6px 0;position:relative;color:rgba(255,255,255,.38);transition:color .15s}
  .nav-item.active{color:var(--clr-coral)}
  .nav-icon{font-size:22px}
  .nav-label{font-size:10px;font-weight:500}
  .nav-badge{position:absolute;top:6px;right:calc(50% - 18px);background:var(--clr-coral);color:#fff;font-size:10px;font-weight:700;min-width:16px;height:16px;border-radius:8px;display:flex;align-items:center;justify-content:center;padding:0 4px}
  .page-header{flex-direction:column;gap:10px}
  .page-title{font-size:22px}
  .cook-step-text{font-size:17px}
  .cook-body{padding:20px 16px}
}

/* ── THEME EDITOR ────────────────────────────────────────────────────────────── */
.te-section { margin-bottom: 24px; }
.te-label { font-size: 12px; font-weight: 600; letter-spacing: .06em; text-transform: uppercase; color: var(--clr-muted); margin-bottom: 10px; }
.te-presets { display: grid; grid-template-columns: repeat(5, 1fr); gap: 8px; }
.te-preset { background: transparent; border: 2px solid transparent; border-radius: var(--radius-md); overflow: hidden; cursor: pointer; transition: border-color .15s; padding: 0; }
.te-preset:hover { border-color: var(--clr-border-mid); }
.te-preset-active { border-color: var(--clr-coral) !important; }
.te-preset-swatch { display: flex; height: 40px; }
.te-ps-sb { width: 32%; flex-shrink: 0; }
.te-ps-bg { flex: 1; display: flex; align-items: center; justify-content: center; }
.te-ps-dot { width: 10px; height: 10px; border-radius: 50%; }
.te-preset-name { font-size: 11px; color: var(--clr-muted); text-align: center; padding: 5px 4px; background: var(--clr-surface); border-top: 1px solid var(--clr-border); font-weight: 500; }
.te-color-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 10px; }
.te-color-row { display: flex; align-items: center; justify-content: space-between; gap: 12px; background: var(--clr-surface); border: 1px solid var(--clr-border); border-radius: var(--radius-md); padding: 12px 14px; }
.te-color-info { flex: 1; min-width: 0; }
.te-color-name { font-size: 14px; font-weight: 500; color: var(--clr-ink); }
.te-color-hint { font-size: 12px; color: var(--clr-muted); margin-top: 2px; }
.te-swatch-wrap { width: 36px; height: 36px; border-radius: 8px; border: 1.5px solid var(--clr-border-mid); display: flex; align-items: center; justify-content: center; cursor: pointer; overflow: hidden; position: relative; flex-shrink: 0; transition: box-shadow .15s; }
.te-swatch-wrap:hover { box-shadow: 0 0 0 3px var(--clr-border-mid); }
.te-color-input { position: absolute; inset: -6px; width: calc(100% + 12px); height: calc(100% + 12px); opacity: 0; cursor: pointer; }
.te-preview { border-radius: var(--radius-md); overflow: hidden; display: flex; height: 64px; border: 1px solid var(--clr-border); }
.te-pv-sb { width: 90px; flex-shrink: 0; display: flex; flex-direction: column; justify-content: center; gap: 6px; padding: 0 14px; }
.te-pv-dot { width: 40px; height: 6px; border-radius: 3px; }
.te-pv-main { flex: 1; display: flex; align-items: center; gap: 10px; padding: 0 14px; }
.te-pv-card { background: rgba(255,255,255,.92); border-radius: 8px; padding: 8px 10px; display: flex; align-items: center; gap: 8px; }
.te-pv-thumb { width: 28px; height: 28px; border-radius: 5px; flex-shrink: 0; }
.te-pv-lines { display: flex; flex-direction: column; gap: 4px; }
.te-pv-line { height: 4px; width: 60px; border-radius: 2px; }
.te-pv-short { width: 36px; }
.te-pv-btn { border-radius: 6px; padding: 7px 12px; font-size: 12px; font-weight: 600; color: #fff; white-space: nowrap; margin-left: auto; }
.te-actions { display: flex; gap: 10px; align-items: center; padding-top: 4px; }
.te-apply-btn { background: var(--clr-coral); color: #fff; border: none; border-radius: var(--radius-md); padding: 11px 22px; font-size: 14px; font-weight: 600; cursor: pointer; transition: opacity .15s; }
.te-apply-btn:hover { opacity: .88; }
.te-reset-btn { background: transparent; color: var(--clr-muted); border: 1px solid var(--clr-border-mid); border-radius: var(--radius-md); padding: 11px 18px; font-size: 14px; font-weight: 500; cursor: pointer; transition: background .15s; }
.te-reset-btn:hover { background: var(--clr-paper-mid); }

@media(max-width:768px) {
  .te-presets { grid-template-columns: repeat(5, 1fr); gap: 6px; }
  .te-color-grid { grid-template-columns: 1fr; }
  .te-actions { flex-direction: column; }
  .te-apply-btn, .te-reset-btn { width: 100%; text-align: center; }
}

/* ── SYNC BAR ── */
.sync-bar{display:flex;align-items:center;gap:8px;padding:10px 16px;font-size:13px;color:var(--clr-muted);background:var(--clr-mint-lt,var(--clr-paper-mid));border-bottom:1px solid var(--clr-border)}
.spinner-sm{width:14px;height:14px;border-radius:50%;border:2px solid var(--clr-border-mid);border-top-color:var(--clr-coral);animation:spin .8s linear infinite;display:inline-block;flex-shrink:0}

/* ── CONNECT BANNER ── */
.connect-banner{display:flex;align-items:center;justify-content:space-between;gap:14px;background:var(--clr-coral-lt);border:1px solid rgba(232,98,58,0.25);border-radius:var(--radius-md);padding:14px 16px;margin:12px 0 4px;font-size:13px;color:var(--clr-coral-dk);line-height:1.5}
.connect-banner strong{display:block;font-weight:600;margin-bottom:2px}
.connect-banner p{color:var(--clr-muted);margin:0}

/* ── EDIT / DELETE ── */
:root { --clr-red: #c0392b; --clr-red-lt: #fae4e0; }
