/* =====================================================
   AIR FRYER JOURNY TOOLKIT — toolkit.css v2.1
   Change --brand to update the entire colour scheme
===================================================== */
.aft-wrap {
    --brand      : #6B9E9A;
    --brand-h    : #568a86;
    --brand-light: #eef6f5;
    --brand-dark : #2d6a65;
    --brand-txt  : #ffffff;
    --bg         : #ffffff;
    --bg-soft    : #f8fbfa;
    --border     : #dde8e7;
    --text       : #1a202c;
    --muted      : #718096;
    --radius     : 12px;
    --rsm        : 8px;
    --shadow     : 0 4px 24px rgba(0,0,0,0.08);
    font-family  : "Segoe UI", system-ui, -apple-system, sans-serif;
    max-width    : 860px;
    margin       : 0 auto;
    color        : var(--text);
    line-height  : 1.5;
    box-sizing   : border-box;
}
.aft-wrap *, .aft-wrap *::before, .aft-wrap *::after { box-sizing: border-box; }
.aft-wrap button { cursor: pointer; font-family: inherit; }
.aft-wrap select, .aft-wrap input { font-family: inherit; }

/* ── HEADER ── */
.aft-header {
    background    : var(--brand);
    color         : var(--brand-txt);
    padding       : 24px 28px 20px;
    text-align    : center;
    border-radius : var(--radius) var(--radius) 0 0;
}
.aft-title    { margin: 0 0 5px; font-size: 1.5rem; font-weight: 900; letter-spacing: -0.02em; }
.aft-subtitle { margin: 0; font-size: 0.875rem; opacity: .9; }

/* ── DASHBOARD ── */
.aft-dash {
    background    : var(--bg-soft);
    border        : 1px solid var(--border);
    border-top    : none;
    border-radius : 0 0 var(--radius) var(--radius);
    padding       : 20px;
}
.aft-dash-intro { font-size:.82rem; color:var(--muted); text-align:center; margin:0 0 16px; font-weight:600; }
.aft-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:12px; }

/* ── TOOL CARDS (dashboard) ── */
.aft-tc {
    background    : var(--bg);
    border        : 2px solid var(--border);
    border-radius : var(--radius);
    padding       : 16px 14px 14px;
    display       : flex;
    flex-direction: column;
    gap           : 6px;
    transition    : all .18s ease;
    box-shadow    : 0 2px 10px rgba(0,0,0,.06);
    position      : relative;
    overflow      : hidden;
}
.aft-tc::after { content:""; position:absolute; top:0; left:0; right:0; height:3px; background:var(--brand); transform:scaleX(0); transition:transform .18s ease; transform-origin:left; }
.aft-tc:hover  { border-color:var(--brand); transform:translateY(-2px); box-shadow:0 6px 20px rgba(107,158,154,.18); }
.aft-tc:hover::after { transform:scaleX(1); }
.aft-tc-icon  { font-size:1.8rem; line-height:1; }
.aft-tc-name  { font-size:.84rem; font-weight:800; color:var(--text); }
.aft-tc-desc  { font-size:.72rem; color:var(--muted); flex:1; line-height:1.4; }
.aft-tc-btn   { width:100%; padding:7px; background:var(--brand); color:#fff; border:none; border-radius:var(--rsm); font-size:.76rem; font-weight:700; transition:background .14s; margin-top:4px; }
.aft-tc-btn:hover { background:var(--brand-h); }

/* ── PANELS ── */
.aft-panel {
    display       : none;
    background    : var(--bg);
    border        : 1px solid var(--border);
    border-top    : none;
    border-radius : 0 0 var(--radius) var(--radius);
}
.aft-panel-on { display: block; }

.aft-panel-nav {
    display        : flex;
    align-items    : center;
    gap            : 12px;
    padding        : 12px 20px;
    background     : var(--brand-light);
    border-bottom  : 1px solid var(--border);
}
.aft-back {
    padding      : 6px 12px;
    background   : #fff;
    border       : 2px solid var(--brand);
    border-radius: var(--rsm);
    color        : var(--brand);
    font-size    : .8rem;
    font-weight  : 700;
    transition   : all .13s;
    white-space  : nowrap;
}
.aft-back:hover       { background:var(--brand); color:#fff; }
.aft-panel-title      { font-size:.9rem; font-weight:800; color:var(--text); }
.aft-pbody            { padding:22px; }

/* ── FORM ── */
.aft-lbl  { display:block; font-size:.7rem; font-weight:700; text-transform:uppercase; letter-spacing:.07em; color:var(--muted); margin-bottom:7px; }
.aft-f    { margin-bottom:18px; }
.aft-row2 { display:grid; grid-template-columns:1fr 1fr; gap:13px; }
.aft-inp, .aft-sel {
    width        : 100%;
    padding      : 10px 13px;
    border       : 2px solid var(--border);
    border-radius: var(--rsm);
    font-size    : .95rem;
    color        : var(--text);
    outline      : none;
    transition   : border-color .14s;
    background   : #fff;
    -moz-appearance: textfield;
}
.aft-inp::-webkit-inner-spin-button,
.aft-inp::-webkit-outer-spin-button { -webkit-appearance:none; }
.aft-inp:focus, .aft-sel:focus { border-color:var(--brand); }
.aft-inp::placeholder { color:#a0aec0; }
.aft-intro-txt { font-size:.85rem; color:var(--muted); margin:0 0 18px; }

/* ── BUTTONS ── */
.aft-btn    { padding:10px 20px; background:var(--brand); color:#fff; border:none; border-radius:var(--rsm); font-size:.9rem; font-weight:800; transition:background .14s,transform .1s; }
.aft-btn:hover   { background:var(--brand-h); transform:translateY(-1px); }
.aft-btn:active  { transform:translateY(0); }
.aft-btn-w       { width:100%; }
.aft-btn-ol      { padding:9px 18px; background:transparent; color:var(--brand); border:2px solid var(--brand); border-radius:var(--rsm); font-size:.85rem; font-weight:700; transition:all .14s; }
.aft-btn-ol:hover { background:var(--brand-light); }

/* ── FOOD GRID ── */
.aft-fgrid { display:grid; grid-template-columns:repeat(5,1fr); gap:8px; }
.aft-fbtn  { display:flex; flex-direction:column; align-items:center; padding:10px 4px; border:2px solid var(--border); border-radius:var(--rsm); background:#fff; font-size:.68rem; font-weight:700; color:var(--muted); transition:all .13s; gap:4px; line-height:1.2; }
.aft-fbtn:hover { border-color:var(--brand); color:var(--brand); background:var(--brand-light); }
.aft-fbtn.aft-on { border-color:var(--brand); background:var(--brand); color:#fff; }
.aft-fic { font-size:1.35rem; line-height:1; }

/* ── CHIPS ── */
.aft-chips { display:flex; flex-wrap:wrap; gap:7px; }
.aft-chip  { padding:5px 12px; border:2px solid var(--border); border-radius:20px; background:#fff; font-size:.78rem; font-weight:700; color:var(--muted); transition:all .13s; }
.aft-chip:hover  { border-color:var(--brand); color:var(--brand); background:var(--brand-light); }
.aft-chip.aft-on { border-color:var(--brand); background:var(--brand); color:#fff; }

/* ── UNIT TOGGLE ── */
.aft-urow { display:flex; gap:8px; align-items:stretch; }
.aft-uinp { flex:1; min-width:0; }
.aft-utog { display:flex; border:2px solid var(--border); border-radius:var(--rsm); overflow:hidden; flex-shrink:0; }
.aft-ubtn { padding:10px 12px; border:none; background:#fff; font-size:.82rem; font-weight:700; color:var(--muted); transition:all .13s; }
.aft-ubtn.aft-on { background:var(--brand); color:#fff; }

/* ── STEPPER ── */
.aft-srow-s  { display:flex; align-items:center; gap:12px; }
.aft-stepper { display:flex; border:2px solid var(--border); border-radius:var(--rsm); overflow:hidden; }
.aft-stbtn   { width:36px; height:36px; border:none; background:#f7fafc; font-size:1.1rem; font-weight:700; color:var(--text); transition:all .12s; }
.aft-stbtn:hover { background:var(--brand-light); color:var(--brand); }
.aft-stval   { width:44px; text-align:center; font-size:.95rem; font-weight:800; background:#fff; border:none; pointer-events:none; }
.aft-hint    { font-size:.8rem; color:var(--muted); }

/* ── TOGGLE SWITCH ── */
.aft-toggle-row { display:flex; align-items:center; gap:12px; }
.aft-toggle     { width:46px; height:26px; cursor:pointer; flex-shrink:0; }
.aft-toggle-track  { width:100%; height:100%; background:#cbd5e0; border-radius:26px; position:relative; transition:background .2s; }
.aft-toggle-track.aft-on { background:var(--brand); }
.aft-toggle-thumb  { position:absolute; width:20px; height:20px; background:#fff; border-radius:50%; top:3px; left:3px; transition:transform .2s; box-shadow:0 1px 4px rgba(0,0,0,.18); }
.aft-toggle-track.aft-on .aft-toggle-thumb { transform:translateX(20px); }
.aft-toggle-lbl    { font-size:.87rem; font-weight:600; color:var(--muted); }

/* ── SLIDER ── */
.aft-slider { -webkit-appearance:none; appearance:none; width:100%; height:6px; background:linear-gradient(to right, var(--brand) 0%, var(--brand) 50%, var(--border) 50%, var(--border) 100%); border-radius:3px; outline:none; cursor:pointer; margin:6px 0 2px; }
.aft-slider::-webkit-slider-thumb { -webkit-appearance:none; width:22px; height:22px; background:var(--brand); border-radius:50%; border:3px solid #fff; box-shadow:0 2px 6px rgba(0,0,0,.2); cursor:pointer; }
.aft-slider::-moz-range-thumb { width:22px; height:22px; background:var(--brand); border-radius:50%; border:3px solid #fff; box-shadow:0 2px 6px rgba(0,0,0,.2); cursor:pointer; }
.aft-slider-labels { display:flex; justify-content:space-between; font-size:.68rem; font-weight:700; color:var(--muted); }
.aft-slider-val    { text-align:center; font-size:1.1rem; font-weight:900; color:var(--brand); margin-top:6px; }
.aft-brand-txt     { color:var(--brand); }

/* ── SEARCH ROW ── */
.aft-srow { display:flex; gap:8px; }
.aft-srow .aft-inp { flex:1; min-width:0; }
.aft-sbtn { padding:10px 16px; background:var(--brand); color:#fff; border:none; border-radius:var(--rsm); font-size:.88rem; font-weight:800; transition:background .14s; flex-shrink:0; }
.aft-sbtn:hover { background:var(--brand-h); }

/* ── HISTORY ── */
.aft-hist-wrap { display:none; margin-bottom:14px; }
.aft-hist-wrap.aft-on { display:block; }
.aft-hist-pills { display:flex; flex-wrap:wrap; gap:6px; margin-top:6px; }
.aft-hpill { padding:4px 11px; border:1.5px solid var(--brand); border-radius:20px; background:var(--brand-light); font-size:.76rem; font-weight:700; color:var(--brand); transition:all .13s; }
.aft-hpill:hover { background:var(--brand); color:#fff; }

/* ── ERROR ── */
.aft-err { display:none; background:#fff5f5; border:1px solid #fed7d7; border-radius:var(--rsm); padding:10px 13px; font-size:.85rem; color:#c53030; font-weight:600; margin-bottom:13px; }
.aft-err.aft-on { display:block; }

/* ── RESULTS ── */
.aft-res { display:none; margin-top:18px; }
.aft-res.aft-on { display:block; }
.aft-res-hdr { display:flex; align-items:center; justify-content:space-between; flex-wrap:wrap; gap:8px; margin-bottom:14px; }
.aft-res-h   { font-size:.9rem; font-weight:800; margin:0; }
.aft-res-sub { font-size:.76rem; color:var(--muted); margin:2px 0 0; }

/* ── COPY BUTTON ── */
.aft-copy { padding:7px 13px; border:2px solid var(--brand); border-radius:var(--rsm); background:transparent; color:var(--brand); font-size:.76rem; font-weight:700; transition:all .14s; }
.aft-copy:hover { background:var(--brand-light); }
.aft-copy.aft-done { background:var(--brand); color:#fff; }

/* ── STATS ── */
.aft-stats { display:grid; grid-template-columns:repeat(3,1fr); gap:10px; margin-bottom:12px; }
.aft-stat  { background:var(--brand-light); border-radius:var(--rsm); padding:13px 8px; text-align:center; }
.aft-stic  { font-size:1.25rem; margin-bottom:3px; line-height:1; }
.aft-stv   { display:block; font-size:1rem; font-weight:900; color:var(--brand); line-height:1.2; }
.aft-stl   { font-size:.63rem; color:var(--muted); font-weight:700; text-transform:uppercase; letter-spacing:.05em; }

/* ── TIPS ── */
.aft-tip  { display:flex; gap:8px; align-items:flex-start; background:#fffbeb; border:1px solid #fbd38d; border-radius:var(--rsm); padding:10px 12px; font-size:.84rem; color:#7b341e; font-weight:600; margin-bottom:9px; }
.aft-gtip { display:flex; gap:8px; align-items:flex-start; background:var(--brand-light); border:1px solid var(--brand); border-radius:var(--rsm); padding:10px 12px; font-size:.84rem; color:var(--brand-dark); font-weight:600; margin-bottom:9px; }

/* ── ACCORDION ── */
.aft-acc { border:2px solid var(--border); border-radius:var(--rsm); margin-bottom:8px; overflow:hidden; transition:border-color .14s; }
.aft-acc:hover { border-color:var(--brand); }
.aft-acc-h { display:flex; align-items:center; justify-content:space-between; padding:11px 15px; cursor:pointer; background:#fff; user-select:none; gap:10px; }
.aft-acc-h:hover { background:var(--brand-light); }
.aft-acc-tit   { font-size:.88rem; font-weight:800; color:var(--text); }
.aft-acc-badge { font-size:.68rem; font-weight:700; padding:2px 8px; border-radius:20px; background:var(--brand-light); color:var(--brand); border:1px solid var(--brand); white-space:nowrap; }
.aft-acc-chev  { font-size:.75rem; color:var(--muted); transition:transform .2s; flex-shrink:0; }
.aft-acc.aft-on .aft-acc-chev { transform:rotate(180deg); }
.aft-acc-b { display:none; padding:12px 15px 14px; border-top:1px solid var(--border); }
.aft-acc.aft-on .aft-acc-b { display:block; }
.aft-acc-notes { font-size:.87rem; color:var(--muted); font-style:italic; margin:0 0 9px; }

/* ── TABLE ── */
.aft-table { width:100%; border-collapse:collapse; font-size:.85rem; }
.aft-table th { background:var(--brand); color:#fff; padding:8px 12px; text-align:left; font-size:.7rem; text-transform:uppercase; letter-spacing:.05em; }
.aft-table td { padding:9px 12px; border-bottom:1px solid var(--border); }
.aft-table tr:last-child td { border-bottom:none; }
.aft-table tr:nth-child(even) td { background:var(--brand-light); }
.aft-badge-start { display:inline-block; padding:2px 8px; border-radius:10px; font-size:.7rem; font-weight:800; background:var(--brand); color:#fff; }

/* ── DONENESS ── */
.aft-don-food { font-size:.82rem; color:var(--muted); font-weight:600; margin:14px 0 8px; }
.aft-don-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:10px; }
.aft-don      { border-radius:var(--rsm); padding:14px 10px; text-align:center; border:2px solid transparent; }
.aft-don-u    { background:#fff5f5; border-color:#fed7d7; }
.aft-don-p    { background:#f0faf4; border-color:#9ae6b4; }
.aft-don-o    { background:#fffbeb; border-color:#fbd38d; }
.aft-don-ic   { font-size:1.8rem; margin-bottom:5px; }
.aft-don-lbl  { font-size:.68rem; font-weight:700; text-transform:uppercase; letter-spacing:.05em; margin-bottom:5px; }
.aft-don-u .aft-don-lbl { color:#c53030; }
.aft-don-p .aft-don-lbl { color:#276749; }
.aft-don-o .aft-don-lbl { color:#7b341e; }
.aft-don-txt  { font-size:.76rem; color:var(--muted); line-height:1.45; }

/* ── CLEANING ── */
.aft-clean-sec { margin-bottom:16px; }
.aft-clean-hd  { font-size:.75rem; font-weight:700; text-transform:uppercase; letter-spacing:.06em; color:var(--brand); margin:0 0 8px; padding-bottom:5px; border-bottom:2px solid var(--brand-light); }
.aft-clean-li  { display:flex; align-items:flex-start; gap:9px; padding:7px 0; border-bottom:1px solid var(--border); font-size:.84rem; }
.aft-clean-li:last-child { border-bottom:none; }
.aft-clean-n   { width:20px; height:20px; background:var(--brand); color:#fff; border-radius:50%; display:flex; align-items:center; justify-content:center; font-size:.65rem; font-weight:800; flex-shrink:0; margin-top:1px; }

/* ── RECIPE CARD ── */
.aft-recipe-card { background:#fff; border:2px solid var(--border); border-radius:var(--radius); padding:18px; animation:aft-fade .3s ease; }
@keyframes aft-fade { from{opacity:0;transform:translateY(6px)} to{opacity:1;transform:translateY(0)} }
.aft-recipe-name { font-size:1.15rem; font-weight:900; color:var(--text); margin:0 0 7px; }
.aft-recipe-tags { display:flex; flex-wrap:wrap; gap:5px; margin-bottom:9px; }
.aft-recipe-tag  { font-size:.68rem; font-weight:700; padding:2px 8px; border-radius:20px; background:var(--brand-light); color:var(--brand); border:1px solid var(--brand); }
.aft-recipe-desc { font-size:.875rem; color:var(--muted); margin-bottom:11px; line-height:1.5; }
.aft-recipe-stats { display:flex; gap:14px; flex-wrap:wrap; }
.aft-recipe-stat  { font-size:.82rem; font-weight:700; color:var(--text); }
.aft-recipe-stat span { color:var(--brand); }

/* ── SHOPPING LIST ── */
.aft-rcard    { background:var(--brand-light); border:1px solid var(--brand); border-radius:var(--rsm); padding:16px; margin-bottom:12px; }
.aft-rhead    { font-size:.7rem; font-weight:700; text-transform:uppercase; letter-spacing:.07em; color:var(--muted); margin:0 0 12px; }
.aft-shoplist { list-style:none; margin:0; padding:0; }
.aft-shopli   { display:flex; align-items:center; gap:9px; padding:7px 0; border-bottom:1px solid rgba(0,0,0,.07); font-size:.875rem; }
.aft-shopli:last-child { border-bottom:none; }
.aft-shopqty  { font-weight:800; color:var(--brand); min-width:70px; }

/* ── NO RESULTS ── */
.aft-nores    { display:none; text-align:center; padding:24px; color:var(--muted); }
.aft-nores.aft-on { display:block; }
.aft-nores-ic { font-size:2rem; margin-bottom:6px; }

/* ── OIL BARS ── */
.aft-bar-wrap  { margin:5px 0 13px; }
.aft-bar-lbl   { font-size:.76rem; font-weight:700; color:var(--muted); margin-bottom:4px; }
.aft-bar-track { height:18px; background:var(--border); border-radius:9px; overflow:hidden; }
.aft-bar-fill  { height:100%; border-radius:9px; background:var(--brand); transition:width .5s ease; display:flex; align-items:center; justify-content:flex-end; padding-right:6px; }
.aft-bar-fill span { font-size:.66rem; font-weight:800; color:#fff; white-space:nowrap; }
.aft-bar-ora   { background:#dd6b20; }
.aft-bar-red   { background:#e53e3e; }

/* ── RESPONSIVE ── */
@media (max-width:660px) {
    .aft-grid     { grid-template-columns:repeat(2,1fr); }
    .aft-fgrid    { grid-template-columns:repeat(3,1fr); }
    .aft-stats    { grid-template-columns:repeat(2,1fr); }
    .aft-don-grid { grid-template-columns:1fr; }
    .aft-row2     { grid-template-columns:1fr; }
    .aft-pbody    { padding:16px; }
    .aft-header   { padding:18px 16px 14px; }
    .aft-title    { font-size:1.2rem; }
    .aft-panel-nav { padding:10px 16px; }
}
@media (max-width:400px) {
    .aft-grid  { grid-template-columns:1fr; }
    .aft-fgrid { grid-template-columns:repeat(2,1fr); }
}
@media print {
    .aft-dash,
    .aft-panel-nav,
    .aft-btn,
    .aft-tc-btn  { display:none !important; }
    .aft-panel-on { display:block !important; }
    .aft-header   { print-color-adjust:exact; -webkit-print-color-adjust:exact; }
}
