:root{
  --paper:#FAF8F4;
  --panel:#F4F1EB;
  --ink:#1B1A17;
  --muted:#6F6A61;
  --line:#E7E2D9;
  --accent:#7C2D3A;
  --sans:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;
  --mono:ui-monospace,"SF Mono","JetBrains Mono","Menlo","Consolas",monospace;
}
*{box-sizing:border-box}
html,body{margin:0;width:100%}
body{
  background:var(--paper);color:var(--ink);font-family:var(--sans);
  -webkit-font-smoothing:antialiased;line-height:1.55;min-height:100vh;
}
a{color:var(--accent);text-decoration:none}
a:hover{text-decoration:underline}
::selection{background:var(--accent);color:#fff}

.eyebrow{font-family:var(--mono);font-size:11px;letter-spacing:.16em;
  text-transform:uppercase;color:var(--muted)}
.wrap{max-width:1180px;margin:0 auto;padding:0 28px}

.brand{display:flex;align-items:center;gap:10px;font-weight:600;letter-spacing:-.01em;color:var(--ink)}
.brand:hover{text-decoration:none}
.brand .mk{font-family:var(--mono);color:var(--accent);font-size:18px;line-height:1;
  border:1.5px solid var(--accent);border-radius:7px;padding:3px 6px}

/* ---------- buttons & fields ---------- */
.btn{display:inline-block;width:100%;padding:14px;border:none;border-radius:11px;
  background:var(--ink);color:var(--paper);font-size:15px;font-weight:600;
  font-family:var(--sans);cursor:pointer;letter-spacing:.01em;text-align:center;
  transition:transform .12s,background .2s}
.btn:hover{background:#000;transform:translateY(-1px);text-decoration:none}
.btn:focus-visible{outline:2px solid var(--accent);outline-offset:2px}
.btn.auto{width:auto;padding:11px 20px}
.btn-outline{display:inline-block;padding:11px 18px;border:1px solid var(--line);
  border-radius:11px;background:#fff;color:var(--ink);font-size:14px;font-weight:600;
  cursor:pointer;transition:border-color .15s,color .15s}
.btn-outline:hover{border-color:var(--ink);text-decoration:none}
.btn-danger{display:inline-block;padding:11px 18px;border:1px solid var(--accent);
  border-radius:11px;background:#fff;color:var(--accent);font-size:14px;font-weight:600;
  cursor:pointer;transition:background .15s}
.btn-danger:hover{background:rgba(124,45,58,.06);text-decoration:none}

.field{margin-bottom:14px}
.field > label{display:block;font-family:var(--mono);font-size:11px;letter-spacing:.1em;
  text-transform:uppercase;color:var(--muted);margin-bottom:7px}
.field input{width:100%;padding:13px 15px;border:1px solid var(--line);border-radius:11px;
  background:#fff;font-size:15px;font-family:var(--sans);color:var(--ink);
  transition:border-color .15s,box-shadow .15s}
.field input::placeholder,.field textarea::placeholder{color:#b6b0a6}
.field input:focus,.field textarea:focus,.field select:focus{outline:none;
  border-color:var(--accent);box-shadow:0 0 0 3px rgba(124,45,58,.12)}
.field textarea,.field select{width:100%;padding:13px 15px;border:1px solid var(--line);
  border-radius:11px;background:#fff;font-size:15px;font-family:var(--sans);
  color:var(--ink);transition:border-color .15s,box-shadow .15s}
.field textarea{resize:vertical;line-height:1.6}
.field .helptext{display:block;font-size:12px;color:var(--muted);margin-top:6px}
.field .helptext .pw-hints{margin:6px 0 0;padding-left:18px}
.field .helptext .pw-hints li{margin:2px 0}
.field .errorlist{margin:6px 0 0;padding:0;list-style:none;color:var(--accent);font-size:13px}

.form-error{background:rgba(124,45,58,.06);border:1px solid var(--accent);color:var(--accent);
  border-radius:10px;padding:11px 14px;font-size:13.5px;margin-bottom:18px}

/* ---------- messages ---------- */
.messages{max-width:1180px;margin:14px auto 0;padding:0 28px;list-style:none}
.messages li{border:1px solid var(--line);background:#fff;border-radius:10px;
  padding:11px 14px;font-size:14px;margin-bottom:8px}
.messages li.error{border-color:var(--accent);color:var(--accent)}

/* ---------- top bar ---------- */
.topbar{border-bottom:1px solid var(--line);background:var(--paper);
  position:sticky;top:0;z-index:10}
.topbar-inner{max-width:1180px;margin:0 auto;padding:14px 28px;
  display:flex;align-items:center;gap:26px}
.topbar nav{display:flex;gap:22px;font-size:14px}
.topbar nav a{color:var(--ink)}
.topbar nav a:hover{color:var(--accent);text-decoration:none}
.topbar nav a.on{color:var(--accent)}
.topbar .spacer{margin-left:auto}
.topbar .who{font-size:13px;color:var(--muted)}
.logout-btn{background:none;border:none;font-family:var(--mono);font-size:12px;
  color:var(--muted);cursor:pointer;padding:6px 8px;border-radius:8px}
.logout-btn:hover{color:var(--accent)}

/* top bar on phones: brand + Salir on one row, nav scrolls below */
@media (max-width:640px){
  .topbar-inner{flex-wrap:wrap;padding:12px 16px;gap:8px 14px}
  .topbar .spacer,.topbar .who{display:none}
  .topbar form{order:2;margin-left:auto}
  .topbar nav{order:3;flex-basis:100%;gap:20px;overflow-x:auto;white-space:nowrap;
    -webkit-overflow-scrolling:touch;padding-bottom:2px}
  .topbar nav a{flex:none}
}

/* ---------- auth split ---------- */
.auth{display:grid;grid-template-columns:1fr 1fr;height:100vh;height:100dvh;overflow:hidden}
.auth > *{min-height:0}
.auth-form{display:flex;flex-direction:column;justify-content:center;overflow-y:auto;
  padding:64px clamp(28px,6vw,96px)}
.auth-inner{width:100%;max-width:380px;margin:0 auto;animation:rise .6s ease both}
@keyframes rise{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:none}}
.auth h1{font-size:clamp(30px,4.2vw,48px);font-weight:600;letter-spacing:-.025em;
  line-height:1.05;margin:22px 0 10px;text-wrap:balance}
.auth .lede{color:var(--muted);margin:0 0 32px;font-size:15.5px;max-width:36ch}
.auth .row-mini{display:flex;justify-content:flex-end;margin-top:14px;font-size:13.5px}
.note-invite{margin-top:30px;padding-top:20px;border-top:1px solid var(--line);
  font-size:13px;color:var(--muted);display:flex;gap:9px;align-items:flex-start}
.note-invite .tag{font-family:var(--mono);font-size:10px;letter-spacing:.08em;
  text-transform:uppercase;color:var(--accent);border:1px solid var(--accent);
  border-radius:5px;padding:2px 6px;white-space:nowrap;margin-top:1px}
.auth-brand{margin-bottom:6px}

.ascii-panel{background:var(--panel);border-left:1px solid var(--line);
  display:flex;align-items:center;justify-content:center;overflow:hidden;position:relative}
.ascii-panel pre{margin:0;font-family:var(--mono);color:var(--ink);
  font-size:9px;line-height:9px;letter-spacing:0;white-space:pre;user-select:none}
.ascii-cap{position:absolute;left:22px;bottom:18px;font-family:var(--mono);
  font-size:10px;letter-spacing:.12em;text-transform:uppercase;color:var(--muted)}

/* on mobile: no ASCII, form takes the whole screen */
@media (max-width:820px){
  .auth{grid-template-columns:1fr}
  .ascii-panel{display:none}
  .auth-form{padding:40px 24px;justify-content:flex-start}
  .auth-inner{padding-top:24px}
  .auth h1{font-size:28px}
  .auth .lede{font-size:14px}
}

/* ---------- simple page (placeholder home) ---------- */
/* top/bottom only: the shorthand would zero .wrap's side padding
   (same specificity, later in the file) */
.page{padding-top:48px;padding-bottom:48px}
.page h1{font-size:30px;font-weight:600;letter-spacing:-.02em;margin:6px 0 10px}
.page .placeholder{border:1px dashed var(--line);border-radius:13px;padding:40px;
  text-align:center;color:var(--muted);background:#fff;margin-top:18px}

/* ---------- recipe list ---------- */
.list-head{display:flex;align-items:flex-end;justify-content:space-between;gap:20px;
  flex-wrap:wrap;margin-bottom:24px}
.list-head h1{font-size:30px;font-weight:600;letter-spacing:-.02em;margin:6px 0 0}
.search-form{flex:1;min-width:240px;max-width:420px}
.search-input{width:100%;font-family:var(--mono);font-size:13px;color:var(--ink);
  border:1px solid var(--line);border-radius:11px;padding:11px 14px;background:#fff;
  transition:border-color .15s,box-shadow .15s}
.search-input::placeholder{color:#b6b0a6}
.search-input:focus{outline:none;border-color:var(--accent);
  box-shadow:0 0 0 3px rgba(124,45,58,.12)}

.cards{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
@media (max-width:860px){.cards{grid-template-columns:repeat(2,1fr)}}
@media (max-width:520px){.cards{grid-template-columns:1fr}}
.card{display:block;border:1px solid var(--line);border-radius:13px;overflow:hidden;
  background:#fff;color:var(--ink);transition:transform .14s,box-shadow .14s}
.card:hover{transform:translateY(-2px);box-shadow:0 8px 26px rgba(27,26,23,.07);
  text-decoration:none}
.card-photo{height:160px;border-bottom:1px solid var(--line);overflow:hidden}
.card-photo img{width:100%;height:100%;object-fit:cover;display:block}
.photo-ph{height:100%;display:flex;flex-direction:column;align-items:center;
  justify-content:center;gap:8px;color:#b9b2a6;
  background:linear-gradient(135deg,rgba(124,45,58,.04),transparent 60%),
    repeating-linear-gradient(45deg,#f1ede5,#f1ede5 10px,#f4f1ea 10px,#f4f1ea 20px)}
.photo-ph svg{width:32px;height:32px;stroke:#c2bcaf;fill:none;stroke-width:1.4}
.photo-ph span{font-family:var(--mono);font-size:10px;letter-spacing:.1em;
  text-transform:uppercase;color:#b0a99c}
.card-body{padding:14px 15px 16px}
.card-body .ttl{font-weight:600;font-size:16px;letter-spacing:-.01em;margin:0 0 4px;
  text-wrap:balance}
.card-body .by{font-size:13px;color:var(--muted);margin:0 0 12px}
.card-body .by b{color:var(--ink);font-weight:600}
.meta{display:flex;gap:14px;font-family:var(--mono);font-size:11px;color:var(--muted);
  font-variant-numeric:tabular-nums}
.meta .diff{color:var(--accent)}
.tags{display:flex;gap:6px;margin-top:12px;flex-wrap:wrap}
.tag-pill{font-family:var(--mono);font-size:10px;letter-spacing:.04em;color:var(--muted);
  border:1px solid var(--line);border-radius:20px;padding:2px 9px}
.empty{border:1px dashed var(--line);border-radius:13px;padding:48px 24px;
  text-align:center;color:var(--muted);background:#fff}
.empty b{color:var(--ink)}

/* ---------- recipe form ---------- */
.recipe-form{max-width:720px;margin-top:18px}
.form-row{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}
@media (max-width:560px){.form-row{grid-template-columns:1fr}}
.form-actions{display:flex;align-items:center;gap:12px;margin-top:24px;
  padding-top:20px;border-top:1px solid var(--line)}
.form-actions .spacer{margin-left:auto}
.form-note{margin-top:22px;border:1px dashed var(--line);border-radius:11px;
  padding:16px 18px;color:var(--muted);font-size:13.5px;background:#fff}

/* ---------- ingredients builder ---------- */
.sections{display:flex;flex-direction:column;gap:14px}
.section{border:1px solid var(--line);border-radius:12px;padding:14px;background:#fff}
.section[data-type="linked"]{border-style:dashed;border-color:var(--accent);
  background:rgba(124,45,58,.03)}
.section-head{display:flex;align-items:center;gap:10px;margin-bottom:10px}
.section-title{flex:1;border:none;border-bottom:1px solid var(--line);border-radius:0;
  padding:6px 2px;font-size:15px;font-weight:600;font-family:var(--sans);
  color:var(--ink);background:transparent}
.section-title::placeholder{color:#b6b0a6;font-weight:400}
.section-title:focus{outline:none;border-bottom-color:var(--accent)}
.section-del{background:none;border:none;font-family:var(--mono);font-size:11px;
  letter-spacing:.04em;color:var(--muted);cursor:pointer;white-space:nowrap}
.section-del:hover{color:var(--accent)}

.rows{display:flex;flex-direction:column;gap:8px}
.row{display:flex;gap:8px;align-items:center}
.row .ac{position:relative;flex:1 1 40%}
.row .ing-input,.row .qty,.row .unit,.row .note{border:1px solid var(--line);
  border-radius:9px;padding:9px 11px;font-size:14px;font-family:var(--sans);
  color:var(--ink);background:#fff}
.row .ing-input{width:100%}
.row .qty{width:64px;text-align:right;font-variant-numeric:tabular-nums}
.row .unit{width:78px}
.row .note{flex:1 1 22%;min-width:80px}
.row input:focus,.row select:focus{outline:none;border-color:var(--accent);
  box-shadow:0 0 0 3px rgba(124,45,58,.12)}
.row-del{background:none;border:none;color:#b6b0a6;cursor:pointer;font-size:14px;
  padding:6px}
.row-del:hover{color:var(--accent)}
.row-add{align-self:flex-start;margin-top:10px;background:none;border:none;
  font-family:var(--mono);font-size:12px;color:var(--accent);cursor:pointer;padding:4px 0}

.linked-pick{display:flex;gap:12px;align-items:center}
.linked-pick .ac{position:relative;flex:1}
.linked-pick .recipe-input{width:100%;border:1px solid var(--line);border-radius:9px;
  padding:9px 11px;font-size:14px;font-family:var(--sans);background:#fff}
.linked-pick .recipe-input:focus{outline:none;border-color:var(--accent);
  box-shadow:0 0 0 3px rgba(124,45,58,.12)}
.mult-wrap{display:inline-flex;align-items:center;gap:4px;font-family:var(--mono);
  color:var(--muted);font-size:14px}
.mult-wrap .mult{width:52px;text-align:center;border:1px solid var(--line);
  border-radius:9px;padding:9px 6px;font-family:var(--mono);font-variant-numeric:tabular-nums}

.ac-menu{display:none;position:absolute;top:calc(100% + 4px);left:0;right:0;z-index:20;
  background:#fff;border:1px solid var(--line);border-radius:10px;overflow:hidden;
  box-shadow:0 8px 26px rgba(27,26,23,.10);max-height:240px;overflow-y:auto}
.ac-item{padding:9px 12px;font-size:14px;cursor:pointer}
.ac-item:hover{background:var(--panel)}
.ac-create{color:var(--accent);font-family:var(--mono);font-size:13px;
  border-top:1px solid var(--line)}

.section-add{display:flex;gap:10px;margin-top:12px;flex-wrap:wrap}

/* ---------- photos in the form ---------- */
.photo-edit-grid{display:flex;flex-wrap:wrap;gap:12px;margin-bottom:14px}
.photo-edit{width:188px;border:1px solid var(--line);border-radius:11px;overflow:hidden;
  background:#fff}
.photo-edit img{width:100%;height:120px;object-fit:cover;display:block}
.photo-edit-ctl{display:flex;justify-content:space-between;gap:8px;padding:8px 11px;
  font-family:var(--mono);font-size:11px;color:var(--muted)}
.photo-edit-ctl label{display:inline-flex;align-items:center;gap:5px;cursor:pointer;
  white-space:nowrap}
.photo-edit-ctl .del{color:var(--accent)}
.file-input{display:block;font-size:13px;color:var(--muted);width:100%;max-width:100%}
.file-input::file-selector-button{font-family:var(--sans);font-size:13px;font-weight:600;
  color:var(--ink);background:#fff;border:1px solid var(--line);border-radius:9px;
  padding:8px 14px;margin-right:12px;cursor:pointer}
.file-input::file-selector-button:hover{border-color:var(--ink)}

/* tag picker: closed list rendered as selectable pills */
.tag-checks{display:flex;flex-wrap:wrap;gap:8px}
.tag-checks div{display:contents}
.tag-checks label{display:inline-flex;align-items:center;border:1px solid var(--line);
  border-radius:20px;padding:6px 14px;font-size:13px;cursor:pointer;color:var(--muted);
  background:#fff;transition:border-color .12s,color .12s,background .12s}
.tag-checks label:hover{border-color:var(--ink)}
.tag-checks label:has(input:checked){border-color:var(--accent);color:var(--accent);
  background:rgba(124,45,58,.06)}
.tag-checks label:has(input:focus-visible){outline:2px solid var(--accent);outline-offset:2px}
.tag-checks input{position:absolute;width:1px;height:1px;opacity:0;margin:0}

.head-actions{display:flex;gap:10px;align-items:center}
.recipe-actions{display:flex;gap:10px;flex:none}

/* ---------- recipe detail ---------- */
.back-link{font-family:var(--mono);font-size:11px;letter-spacing:.1em;
  text-transform:uppercase;color:var(--muted)}
.back-link:hover{color:var(--accent)}
.recipe-head{display:flex;align-items:flex-start;justify-content:space-between;gap:24px;
  border-bottom:1px solid var(--line);padding-bottom:22px;margin-bottom:8px}
.recipe-head-main{flex:1;min-width:0}
@media (max-width:560px){.recipe-head{flex-direction:column;gap:14px}}
.recipe-head h1{font-size:clamp(28px,3.4vw,40px);font-weight:600;letter-spacing:-.025em;
  line-height:1.06;margin:14px 0 8px;text-wrap:balance}
.recipe-head .by{color:var(--muted);font-size:14.5px;margin:0}
.recipe-head .by b{color:var(--ink);font-weight:600}
.recipe-head .meta{margin-top:12px;font-size:12px;gap:16px}
.recipe-head .desc{margin:14px 0 0;font-size:15.5px;color:var(--ink);max-width:62ch}
.recipe-head .tags{margin-top:14px}
.recipe-source{font-family:var(--mono);font-size:12px;letter-spacing:.04em;
  color:var(--muted);margin:10px 0 0}
.recipe-source b{color:var(--ink);font-weight:600}
.field .ac{position:relative}

.recipe-body{display:grid;grid-template-columns:260px 1fr;gap:44px;margin-top:30px}
@media (max-width:760px){.recipe-body{grid-template-columns:1fr;gap:30px}}
.col-label{font-family:var(--mono);font-size:11px;letter-spacing:.14em;
  text-transform:uppercase;color:var(--muted);margin-bottom:10px}

.ing-col .sec-title{font-family:var(--mono);font-size:11px;letter-spacing:.1em;
  text-transform:uppercase;color:var(--ink);margin:20px 0 8px;display:flex;
  align-items:center;gap:10px}
.ing-col .sec-title::after{content:"";flex:1;height:1px;background:var(--line)}
.ing-col .sec-title .mult{color:var(--accent)}
.ing-col .sub-link{display:inline-block;margin:8px 0 4px;font-family:var(--mono);
  font-size:11px;letter-spacing:.04em;color:var(--accent)}
.ing{display:flex;justify-content:space-between;gap:12px;padding:7px 0;
  border-bottom:1px dotted var(--line);font-size:14.5px}
.ing .q{font-family:var(--mono);font-size:12.5px;color:var(--muted);
  font-variant-numeric:tabular-nums;white-space:nowrap;text-align:right}
.ing .note{color:var(--muted);font-size:13px}
.linked{display:flex;flex-direction:column;gap:5px;padding:11px 13px;
  border:1px dashed var(--accent);border-radius:10px;background:rgba(124,45,58,.04);
  font-size:13.5px}
.linked .tag{font-family:var(--mono);font-size:10px;letter-spacing:.08em;
  text-transform:uppercase;color:var(--accent)}

.elaboracion{font-size:15.5px;line-height:1.75;max-width:64ch}
.elaboracion p{margin:0 0 14px}
.elaboracion p:last-child{margin-bottom:0}
.elaboracion .muted{color:var(--muted)}
.sub-elaboracion{margin-top:26px;padding-top:20px;border-top:1px solid var(--line)}
.sub-elab-title{display:flex;align-items:baseline;gap:12px;flex-wrap:wrap;
  font-family:var(--mono);font-size:11px;letter-spacing:.1em;text-transform:uppercase;
  color:var(--ink);margin-bottom:10px}
.sub-elab-title a{font-family:var(--mono);font-size:11px;letter-spacing:.02em;
  text-transform:none;color:var(--accent)}

.photos{margin-top:40px;border-top:1px solid var(--line);padding-top:26px;
  display:flex;flex-direction:column;align-items:center;gap:16px}
.photo-row{display:flex;gap:14px;flex-wrap:wrap;justify-content:center}
.photo-row img{width:200px;height:150px;object-fit:cover;border-radius:11px;
  border:1px solid var(--line)}
.photos-empty{width:220px;height:120px;border-radius:11px;border:1px dashed var(--line);
  display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;
  color:#b0a99c;background:repeating-linear-gradient(45deg,#f1ede5,#f1ede5 10px,#f4f1ea 10px,#f4f1ea 20px)}
.photos-empty svg{width:26px;height:26px;stroke:#c2bcaf;fill:none;stroke-width:1.4}
.photos-empty span{font-family:var(--mono);font-size:10px;letter-spacing:.1em;text-transform:uppercase}
.photo-row img{cursor:zoom-in}

/* ---------- lightbox ---------- */
.lightbox{position:fixed;inset:0;z-index:1000;display:flex;align-items:center;
  justify-content:center;background:rgba(20,19,16,.93);
  animation:lb-in .15s ease both}
.lightbox[hidden]{display:none}
@keyframes lb-in{from{opacity:0}to{opacity:1}}
.lb-fig{margin:0;display:flex;flex-direction:column;align-items:center;gap:14px;
  max-width:90vw;max-height:88vh}
.lb-img{max-width:90vw;max-height:82vh;object-fit:contain;border-radius:8px;
  box-shadow:0 12px 50px rgba(0,0,0,.45)}
.lb-cap{font-family:var(--mono);font-size:12px;letter-spacing:.04em;color:#e7e2d9;
  text-align:center;max-width:80vw}
.lb-close{position:fixed;top:18px;right:22px;background:none;border:none;color:#e7e2d9;
  font-size:26px;line-height:1;cursor:pointer;padding:6px}
.lb-close:hover{color:#fff}
.lb-nav{position:fixed;top:50%;transform:translateY(-50%);background:none;border:none;
  color:#e7e2d9;font-size:56px;line-height:1;cursor:pointer;padding:8px 16px;
  user-select:none}
.lb-nav:hover{color:#fff}
.lb-prev{left:8px}
.lb-next{right:8px}
.lb-count{position:fixed;bottom:20px;left:50%;transform:translateX(-50%);
  font-family:var(--mono);font-size:12px;letter-spacing:.1em;color:#b0a99c}
@media (prefers-reduced-motion:reduce){.lightbox{animation:none}}

/* ---------- shopping list ---------- */
/* minmax(0,1fr) + min-width:0: without them Safari sizes the track to
   the widest nowrap recipe title and the whole page overflows */
.shopping-layout{display:grid;grid-template-columns:320px minmax(0,1fr);gap:34px;margin-top:24px}
@media (max-width:760px){.shopping-layout{grid-template-columns:minmax(0,1fr);gap:26px}}
.shopping-select,.shopping-result{min-width:0}
.shopping-select{display:flex;flex-direction:column;gap:12px;align-self:start}
.shop-search{margin:0}
.select-box{border:1px solid var(--line);border-radius:12px;background:#fff;
  max-height:440px;overflow-y:auto}
.select-item{display:flex;align-items:center;gap:10px;padding:11px 14px;cursor:pointer;
  border-bottom:1px solid var(--line);transition:background .1s}
.select-item:last-of-type{border-bottom:none}
.select-item:hover{background:var(--panel)}
.select-item:has(input:checked){background:rgba(124,45,58,.07)}
.select-item input{margin:0;flex:none;accent-color:var(--accent)}
.select-item .si-title{font-size:14px;font-weight:600;flex:1;min-width:0;
  overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.select-item:has(input:checked) .si-title{color:var(--accent)}
.select-item .si-by{font-family:var(--mono);font-size:11px;color:var(--muted);flex:none}
.select-empty{padding:16px 14px;color:var(--muted);font-size:13px;text-align:center}
.select-foot{display:flex;align-items:center;justify-content:space-between;gap:12px}
.sel-count{font-family:var(--mono);font-size:12px;color:var(--muted)}

.result-head{display:flex;align-items:center;justify-content:space-between;gap:16px;
  margin-bottom:6px}
.result-recipes{font-family:var(--mono);font-size:12px;color:var(--muted);
  margin:0 0 18px;line-height:1.5}
.shop-list{list-style:none;margin:0;padding:0}
.shop-line{display:flex;justify-content:space-between;gap:16px;align-items:baseline;
  padding:11px 2px;border-bottom:1px dotted var(--line)}
.sl-name{font-size:15.5px}
.sl-amount{font-family:var(--mono);font-size:13px;color:var(--accent);white-space:nowrap;
  font-variant-numeric:tabular-nums}

@media print{
  .topbar,.no-print,.messages{display:none!important}
  .shopping-layout{display:block}
  .page{padding:0}
  .sl-amount{color:#000}
  a[href]:after{content:""}
}

/* ---------- pagination ---------- */
.pagination{display:flex;align-items:center;justify-content:center;gap:18px;
  margin-top:28px}
.pagination .page-link{display:inline-flex;align-items:center;gap:6px;
  border:1px solid var(--line);border-radius:10px;padding:9px 14px;background:#fff;
  color:var(--ink);font-size:14px;transition:border-color .15s,color .15s}
.pagination .page-link:hover{border-color:var(--accent);color:var(--accent);
  text-decoration:none}
.pagination .page-current{font-family:var(--mono);font-size:12px;letter-spacing:.06em;
  color:var(--muted);font-variant-numeric:tabular-nums}
.pagination .disabled{opacity:.4;pointer-events:none}

/* ---------- phone tweaks (kept last so they win over base rules) ---------- */
@media (max-width:560px){
  .wrap{padding:0 18px}
  .page{padding-top:32px;padding-bottom:32px}
  .list-head{align-items:stretch;gap:14px}
  .list-head h1{font-size:24px}
  .head-actions{flex-wrap:wrap;width:100%;gap:10px}
  .head-actions .search-form{flex:1 1 100%;min-width:0;max-width:none}
  .head-actions .btn.auto{flex:1 1 100%}

  /* ingredient builder rows stack: ingredient on top, the rest below */
  .row{flex-wrap:wrap}
  .row .ac{flex:1 1 100%}
  .row .qty{flex:0 0 auto}
  .row .note{flex:1 1 auto;min-width:0}
  .section-add{flex-direction:column}
  .section-add .btn-outline{width:100%;text-align:center}

  .recipe-head h1{font-size:26px}
  h1{overflow-wrap:anywhere}

  /* shopping list: long consolidated amounts must wrap, not overflow */
  .sl-amount{white-space:normal;text-align:right}
  .result-head{flex-wrap:wrap}
}

@media (prefers-reduced-motion:reduce){*{animation:none!important;transition:none!important}}

/* ---------- rellenar con IA ---------- */
.extraction-page{max-width:620px} /* narrow single-column page, centered by .wrap */
.extraction-intro{color:var(--muted);margin:0 0 26px}

.extraction-loading{display:flex;flex-direction:column;align-items:center;gap:10px;
  margin-top:26px;padding:36px 20px;border:1px dashed var(--line);border-radius:13px;
  background:var(--panel);text-align:center}
.extraction-loading[hidden]{display:none}
.extraction-loading .scan{font-family:var(--mono);font-size:18px;line-height:1;
  letter-spacing:2px;color:var(--accent);user-select:none}
.extraction-loading .label{font-family:var(--mono);font-size:13px;color:var(--ink)}
.extraction-loading .hint{font-size:12px;color:var(--muted)}

/* while extracting, the panel is the only thing on screen */
#extraction-form.is-loading .field,
#extraction-form.is-loading .form-actions{display:none}
