:root{
  --ink:#211b15; --muted:#8a7a6b; --paper:#fffaf2; --card:#f8efe2;
  --dark:#1b130f; --dark2:#3f342b; --line:#e5d7c6; --gold:#ffc928;
  --accent:#c96718; --accent2:#913719; --green:#577d4c;
}
*{box-sizing:border-box;-webkit-tap-highlight-color:transparent}
html,body{margin:0;padding:0}
body{font-family:-apple-system,BlinkMacSystemFont,"Apple SD Gothic Neo","Malgun Gothic",sans-serif;background:var(--paper);color:var(--ink);font-size:16px}
button,input{font:inherit}
button{border:0;cursor:pointer}
.app-shell{min-height:100vh;padding-bottom:24px;background:#f8efe2;max-width:520px;margin:0 auto}

/* ---- Hero: clean vertical flow, no absolute overlap ---- */
.hero{display:flex;flex-direction:column;gap:14px;padding:18px 16px 20px;background:linear-gradient(180deg,#17100d,#241710 70%,#2a1c15);color:#fff}
.hero-top{display:flex;align-items:center;gap:14px}
.gear,.back{flex:0 0 auto;display:flex;align-items:center;justify-content:center;width:52px;height:52px;border-radius:16px;background:rgba(255,255,255,.13);color:#fff;font-size:28px;box-shadow:inset 0 0 0 1px rgba(255,255,255,.14)}
.hero-title{min-width:0}
.eyebrow{font-size:17px;font-weight:800;color:#ffd9a8}
.hero-title h1{font-size:30px;line-height:1.12;margin:3px 0 0;letter-spacing:0;color:#fff2d4;font-weight:900;word-break:keep-all}

.hero-food{display:block;width:100%;max-width:300px;height:150px;margin:0 auto;object-fit:contain;filter:drop-shadow(0 14px 22px rgba(0,0,0,.5))}

.hero-ratings{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.member-rating{display:flex;align-items:center;gap:10px;min-width:0;background:rgba(44,35,27,.82);border:1px solid rgba(255,255,255,.18);border-radius:16px;padding:10px;box-shadow:0 6px 16px rgba(0,0,0,.22)}
.member-rating img{flex:0 0 auto;width:44px;height:44px;border-radius:50%;background:#fff;object-fit:cover}
.member-rating>div{min-width:0}
.member-rating strong{display:block;font-size:16px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.stars{color:var(--gold);letter-spacing:1px;white-space:nowrap;font-size:14px}
.stars .off{color:rgba(255,255,255,.5)}

.hero-actions{display:flex;align-items:stretch;gap:10px;margin-top:2px}
.refresh{flex:0 0 auto;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;background:rgba(36,28,22,.72);color:#fff;border:1px solid rgba(255,255,255,.2);border-radius:16px;padding:10px 16px;font-weight:800;font-size:13px;line-height:1.2}
.cook-orb{flex:1;display:flex;align-items:center;justify-content:center;gap:10px;border-radius:18px;background:radial-gradient(circle at 30% 20%,#f0942b,#c96517 60%,#8b2d14);color:#fff;border:2px solid rgba(255,255,255,.5);box-shadow:0 10px 26px rgba(0,0,0,.4);font-weight:900;font-size:20px;padding:16px}
.cook-orb .pot{font-size:26px}

/* ---- Toolbar ---- */
.toolbar{display:grid;grid-template-columns:1fr;gap:12px;padding:16px 16px 8px}
.searchbox{display:flex;align-items:center;gap:12px;background:#fff;border:1px solid var(--line);border-radius:14px;padding:13px 16px;box-shadow:0 4px 14px rgba(51,34,20,.09)}
.searchbox span{font-size:24px}.searchbox input{width:100%;border:0;outline:0;background:transparent;font-size:17px}
.sorts{display:grid;grid-template-columns:repeat(4,1fr);gap:8px}
.sorts button{min-height:58px;background:#fff;border:1px solid var(--line);border-radius:14px;color:#2a211a;font-size:13px;font-weight:800;line-height:1.2;padding:6px 4px;box-shadow:0 4px 12px rgba(51,34,20,.08)}
.sorts button.active{background:#241914;color:#fff;border-color:#241914}

/* ---- Recipe cards: image small, ratings full-width row below, nothing clipped ---- */
.recipe-list{display:grid;gap:12px;padding:8px 16px}
.recipe-card{display:grid;grid-template-columns:96px 1fr;gap:12px;align-items:start;background:linear-gradient(135deg,#5f544a,#3f352d);color:#fff;border-radius:18px;padding:12px;box-shadow:0 8px 20px rgba(41,31,23,.18)}
.recipe-card>img{width:96px;height:96px;object-fit:cover;border-radius:14px;background:#2d211a}
.recipe-info{min-width:0;display:flex;flex-direction:column;gap:5px}
.recipe-card h2{font-size:19px;line-height:1.2;margin:0;color:#fff;word-break:keep-all;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.recipe-time{font-size:13px;font-weight:700;color:#ffd9a8}
.ingredients{color:#e8dccf;font-size:13px;line-height:1.4;margin:0;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.recipe-side{grid-column:1 / -1;display:flex;flex-direction:column;gap:8px}
.card-ratings{display:grid;grid-template-columns:1fr 1fr;gap:6px 12px}
.card-rating-row{display:flex;align-items:center;gap:6px;min-width:0}
.card-rating-row img{flex:0 0 auto;width:24px;height:24px;border-radius:50%;background:#fff;object-fit:cover}
.card-rating-name{font-size:12px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.card-rating-stars{font-size:12px;letter-spacing:0;margin-left:auto}
.cook-badge{align-self:flex-start;display:inline-flex;align-items:center;gap:5px;padding:6px 12px;border-radius:10px;background:rgba(34,25,20,.45);color:#fff;font-weight:800;font-size:13px}
.empty{padding:30px;text-align:center;color:var(--muted)}
.top-page{min-height:100vh;background:var(--paper);padding:18px}
.top-row{display:flex;align-items:center;gap:12px;margin-bottom:16px}.top-row .back{background:#2b211b}.top-row h1{margin:0;font-size:26px}
.detail-frame{width:100%;height:min(78vh,760px);border:0;border-radius:16px;background:#fff;margin-top:14px;box-shadow:0 3px 18px rgba(47,31,18,.1)}
.panel{background:#fff;border:1px solid var(--line);border-radius:16px;padding:16px;margin-top:14px}.panel h2{margin:0 0 12px}
.rate-row{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:10px 0;border-top:1px solid #f0e4d5}.rate-row:first-of-type{border-top:0}
.rate-person{display:flex;align-items:center;gap:10px;font-weight:800}.rate-person img{width:38px;height:38px;border-radius:50%}
.star-btn{background:transparent;color:#b9a897;font-size:28px;padding:0 1px}.star-btn.on{color:var(--gold)}
.done-row{display:flex;align-items:center;gap:10px;margin-top:14px}
.done-btn{flex:1;min-width:0;height:52px;border-radius:14px;background:var(--accent);color:#fff;font-weight:900;font-size:17px}
.cook-current{height:52px;min-width:96px;display:inline-flex;align-items:center;justify-content:center;border-radius:14px;background:#fff7ec;border:1px solid #edd6bf;color:#7b3c17;font-weight:950;white-space:nowrap}
.save-btn{width:100%;height:52px;border-radius:14px;background:var(--accent);color:#fff;font-weight:900;font-size:17px;margin-top:14px}
.save-btn:disabled{opacity:.55}
.family-form{display:grid;gap:10px}.family-form input{height:48px;border:1px solid var(--line);border-radius:12px;padding:0 12px;background:#fff}
.album-picker{position:relative;display:flex;align-items:center;justify-content:center;min-height:48px;border:1px dashed #c9aa8c;border-radius:12px;background:#fff7ec;color:#7b3c17;font-weight:900}
.album-picker input{position:absolute;inset:0;opacity:0}
.avatar-preview{display:flex;align-items:center;gap:10px;padding:10px;border:1px solid var(--line);border-radius:12px;background:#fff}
.avatar-preview img{width:48px;height:48px;border-radius:50%;object-fit:cover;background:#fff2e4}
.family-card{display:flex;align-items:center;gap:12px;padding:10px 0;border-top:1px solid #f0e4d5}.family-card img{width:48px;height:48px;border-radius:50%;background:#fff}.family-card button{margin-left:auto;background:#f3e4d6;color:#7b2c1a;border-radius:10px;padding:9px 12px;font-weight:800}
.family-card.just-added{margin:8px -6px 0;padding:10px 6px;border-radius:12px;background:#fff7ec;box-shadow:inset 0 0 0 1px #ecc7a4}
.appver{text-align:center;color:var(--muted);font-size:12px;margin:18px}
/* Phone safe-area + no horizontal scroll (primary target: POCO X6 Pro ~393px) */
@media (max-width:520px){
  body{overflow-x:hidden}
  .app-shell{width:100%;overflow-x:hidden;padding-bottom:calc(28px + env(safe-area-inset-bottom))}
  .appver{margin:18px 18px calc(18px + env(safe-area-inset-bottom))}
}

/* Wider screens: same flow layout, scaled up */
@media (min-width:720px){
  .app-shell{max-width:760px}
  .eyebrow{font-size:20px}
  .hero-title h1{font-size:38px}
  .hero-food{max-width:360px;height:190px}
  .member-rating img{width:54px;height:54px}
  .member-rating strong{font-size:18px}
  .stars{font-size:16px}
  .cook-orb{font-size:23px}
  .sorts button{min-height:66px;font-size:15px}
  .recipe-card{grid-template-columns:120px 1fr}
  .recipe-card>img{width:120px;height:120px}
  .recipe-card h2{font-size:21px}
}
