:root{--ink:#211821;--muted:#766979;--pink:#f40986;--rose:#ffb5dc;--cream:#fff8fc;--paper:#fff;--line:#efdbe7;--shadow:0 18px 44px rgba(57,18,43,.10);--soft:rgba(244,9,134,.09)}
*{box-sizing:border-box}body{margin:0;font-family:ui-sans-serif,-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;color:var(--ink);background:radial-gradient(circle at 8% -8%,rgba(244,9,134,.16),transparent 32%),radial-gradient(circle at 96% 0,rgba(255,181,220,.25),transparent 28%),linear-gradient(180deg,#fffafd,#f8f4f7);min-height:100vh}a{color:inherit;text-decoration:none}.shell{max-width:1240px;margin:0 auto;padding:28px 18px 54px}.topbar{position:sticky;top:0;z-index:10;display:flex;justify-content:space-between;align-items:center;gap:16px;padding:12px 20px;background:rgba(255,255,255,.84);backdrop-filter:blur(18px);border-bottom:1px solid var(--line)}.brand{display:flex;align-items:center;gap:10px;color:var(--ink)}.brand span{display:grid;place-items:center;width:40px;height:40px;border-radius:15px;background:linear-gradient(135deg,var(--pink),var(--rose));color:#fff;font-weight:950}.topbar nav{display:flex;gap:8px;flex-wrap:wrap}.topbar nav a{padding:9px 11px;border-radius:999px;color:#4d3e4b;font-weight:750}.topbar nav a:hover{background:#fff1f8;color:var(--pink)}.hero{display:flex;justify-content:space-between;gap:18px;align-items:flex-end;margin-bottom:18px}.hero h1{font-size:clamp(2rem,4vw,3.4rem);letter-spacing:-.06em;line-height:.95;margin:0 0 10px}.hero p{margin:0;color:var(--muted);line-height:1.55;max-width:680px}.kicker{display:inline-flex;padding:7px 11px;border-radius:999px;background:#fff1f8;color:#aa145f;font-weight:900;font-size:.76rem;text-transform:uppercase;letter-spacing:.08em;margin-bottom:10px}.card{background:rgba(255,255,255,.94);border:1px solid var(--line);border-radius:26px;padding:20px;box-shadow:var(--shadow)}.stats{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:12px;margin-bottom:18px}.stat{padding:16px;border-radius:22px;background:linear-gradient(180deg,#fff,#fff7fb);border:1px solid var(--line)}.stat strong{display:block;font-size:1.8rem;letter-spacing:-.04em}.stat span{color:var(--muted);font-weight:750;font-size:.86rem}.toolbar{display:grid;grid-template-columns:1fr auto;gap:12px;align-items:start;margin-bottom:16px}.searchbox{position:relative}.searchbox input{width:100%;border:1px solid var(--line);border-radius:22px;background:#fff;padding:16px 18px 16px 46px;font:inherit;font-weight:700;box-shadow:0 12px 26px rgba(57,18,43,.06)}.searchbox:before{content:"⌕";position:absolute;left:18px;top:12px;color:var(--pink);font-size:1.4rem}.chipbar{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:20px}.chip,.badge{--badge:var(--pink);display:inline-flex;align-items:center;gap:5px;border-radius:999px;border:1px solid color-mix(in srgb,var(--badge) 28%,#fff);background:color-mix(in srgb,var(--badge) 12%,#fff);color:color-mix(in srgb,var(--badge) 64%,#3d2536);padding:6px 10px;font-size:.8rem;font-weight:900}.chip{cursor:pointer}.chip.is-active{background:var(--badge);color:#fff;border-color:var(--badge)}.recipe-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:16px}.recipe-card{overflow:hidden;padding:0;display:flex;flex-direction:column;min-height:310px;transition:transform .18s ease,box-shadow .18s ease}.recipe-card:hover{transform:translateY(-3px);box-shadow:0 24px 56px rgba(57,18,43,.14)}.recipe-img{height:180px;background:linear-gradient(135deg,#ffe3f1,#fff7fb);display:grid;place-items:center;color:#b61b69;font-size:2rem;font-weight:950;position:relative;overflow:hidden}.recipe-img img{width:100%;height:100%;object-fit:cover}.fav{position:absolute;right:12px;top:12px;display:grid;place-items:center;width:36px;height:36px;border-radius:999px;background:rgba(255,255,255,.9);color:#c5a9ba;font-size:1.2rem}.fav.on{color:#f40986}.recipe-body{padding:16px;display:flex;flex-direction:column;gap:10px;flex:1}.recipe-body h3{margin:0;font-size:1.16rem;letter-spacing:-.02em}.meta{display:flex;gap:8px;flex-wrap:wrap}.muted{color:var(--muted)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;min-height:42px;padding:0 15px;border-radius:999px;border:1px solid var(--line);background:#fff;color:#5e4d5c;font-weight:850;cursor:pointer}.btn.primary{background:linear-gradient(135deg,var(--pink),#ff62b7);border:0;color:#fff;box-shadow:0 12px 24px rgba(244,9,134,.18)}.btn.danger{background:#fff1f4;color:#a31b4a}.form{display:grid;gap:14px}.field label{display:block;margin-bottom:6px;color:#695867;font-weight:850;font-size:.9rem}.input,.textarea,.select{width:100%;border:1px solid var(--line);border-radius:15px;background:#fff;padding:12px 13px;font:inherit}.textarea{min-height:120px;resize:vertical}.input:focus,.textarea:focus,.select:focus{outline:0;border-color:var(--pink);box-shadow:0 0 0 4px rgba(244,9,134,.12)}.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px}.multi{min-height:120px}.table{width:100%;border-collapse:collapse}.table th,.table td{padding:11px;border-bottom:1px solid #f1e2eb;text-align:left}.table th{color:#7b6675;font-size:.82rem;text-transform:uppercase;letter-spacing:.05em}.login-wrap{min-height:100vh;display:grid;place-items:center;padding:20px}.login-card{width:min(430px,100%)}.login-logo{width:58px;height:58px;border-radius:20px;background:linear-gradient(135deg,var(--pink),var(--rose));display:grid;place-items:center;color:#fff;font-weight:950;font-size:1.2rem;margin-bottom:14px}.alert{padding:12px 14px;border-radius:14px;margin-bottom:12px;font-weight:750}.alert.err{background:#ffe8ef;color:#9d164e}.alert.ok{background:#e9f8ef;color:#1f7043}.detail-hero{display:grid;grid-template-columns:1.15fr .85fr;gap:18px;align-items:stretch;margin-bottom:18px}.detail-image{min-height:390px;border-radius:30px;overflow:hidden;background:linear-gradient(135deg,#ffe3f1,#fff);box-shadow:var(--shadow);display:grid;place-items:center;color:#b61b69;font-size:3rem;font-weight:950}.detail-image img{width:100%;height:100%;object-fit:cover}.detail-title{display:flex;flex-direction:column;justify-content:center}.detail-title h1{font-size:clamp(2rem,4vw,3.5rem);line-height:.96;letter-spacing:-.06em;margin:10px 0}.detail-grid{display:grid;grid-template-columns:.75fr 1.25fr;gap:16px}.content-block{white-space:pre-wrap;line-height:1.65}.ingredients{display:grid;gap:8px}.ingredient{display:grid;grid-template-columns:80px 70px 1fr;gap:8px;padding:9px 0;border-bottom:1px solid #f1e2eb}.steps{counter-reset:step;display:grid;gap:12px}.step{counter-increment:step;display:grid;grid-template-columns:40px 1fr;gap:10px;align-items:start}.step:before{content:counter(step);display:grid;place-items:center;width:34px;height:34px;border-radius:12px;background:#fff1f8;color:var(--pink);font-weight:950}.gallery{display:grid;grid-template-columns:repeat(4,1fr);gap:10px}.gallery img{width:100%;height:120px;object-fit:cover;border-radius:16px}.ingredient-rows,.step-rows{display:grid;gap:8px}.ingredient-row{display:grid;grid-template-columns:110px 110px 1fr 42px;gap:8px}.step-row{display:grid;grid-template-columns:1fr 42px;gap:8px}.iconbtn{min-height:42px;border-radius:13px;border:1px solid var(--line);background:#fff;cursor:pointer;font-weight:950}@media(max-width:980px){.recipe-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.stats,.detail-hero,.detail-grid{grid-template-columns:1fr}.toolbar{grid-template-columns:1fr}.detail-image{min-height:270px}}@media(max-width:640px){.topbar,.hero{align-items:flex-start;flex-direction:column}.topbar nav{width:100%;overflow:auto;flex-wrap:nowrap}.recipe-grid,.form-grid,.stats{grid-template-columns:1fr}.shell{padding-top:18px}.ingredient-row{grid-template-columns:1fr 1fr}.ingredient-row input:nth-child(3){grid-column:1/-1}.ingredient-row button{grid-column:1/-1}.ingredient{grid-template-columns:64px 52px 1fr}.gallery{grid-template-columns:repeat(2,1fr)}}
/* Favorite cards */
.recipe-img-link{position:absolute;inset:0;display:grid;place-items:center}
.favorite-form{position:absolute;right:12px;top:12px;z-index:2}
.fav{position:static;border:0;cursor:pointer;box-shadow:0 8px 20px rgba(57,18,43,.12)}
.fav:hover{transform:scale(1.04);color:#f40986}
.field small{display:block;margin-top:7px}
.quick-capture{display:grid;gap:10px;margin:0 0 12px;padding:14px;border:1px dashed #e9c8da;border-radius:20px;background:linear-gradient(135deg,#fff8fc,#fff)}
.quick-capture strong{display:block;margin-bottom:3px}
.quick-capture p{margin:0;font-size:.9rem}
.quick-capture .textarea{min-height:96px}
.brand span img{width:25px;height:25px;display:block}

@media(max-width:760px){
  body{background:linear-gradient(180deg,#fff8fc,#fbf3f8)}
  .topbar{position:sticky;top:0;padding:10px 12px;gap:10px;background:rgba(255,255,255,.94)}
  .brand{width:100%;font-size:.95rem;font-weight:900}
  .brand span{width:36px;height:36px;border-radius:13px}
  .topbar nav{width:100%;display:flex;gap:7px;overflow-x:auto;flex-wrap:nowrap;padding:2px 2px 6px;scrollbar-width:none}
  .topbar nav::-webkit-scrollbar{display:none}
  .topbar nav a{flex:0 0 auto;padding:9px 12px;background:#fff6fb;border:1px solid #f3d9e8;font-size:.86rem}
  .shell{padding:16px 12px 34px}
  .hero{gap:12px;margin-bottom:14px}
  .hero h1{font-size:clamp(1.75rem,9vw,2.55rem);letter-spacing:-.045em;line-height:1}
  .hero p{font-size:.95rem}
  .hero .btn{width:100%}
  .kicker{font-size:.68rem;padding:6px 9px}
  .card{border-radius:22px;padding:15px;box-shadow:0 12px 30px rgba(57,18,43,.08)}
  .stats{grid-template-columns:repeat(2,minmax(0,1fr));gap:9px}
  .stat{padding:13px;border-radius:18px}
  .stat strong{font-size:1.45rem}
  .stat span{font-size:.78rem}
  .toolbar{gap:10px;margin-bottom:12px}
  .toolbar .btn{width:100%}
  .searchbox input{min-height:50px;border-radius:18px;padding:14px 14px 14px 42px;font-size:16px}
  .searchbox:before{left:16px;top:10px}
  .chipbar{gap:7px;overflow-x:auto;flex-wrap:nowrap;margin:0 -12px 16px;padding:0 12px 4px;scrollbar-width:none}
  .chipbar::-webkit-scrollbar{display:none}
  .chip{flex:0 0 auto;padding:8px 11px}
  .recipe-grid{grid-template-columns:1fr;gap:13px}
  .recipe-card{min-height:0;border-radius:24px}
  .recipe-img{height:158px}
  .favorite-form{right:10px;top:10px}
  .fav{width:42px;height:42px;font-size:1.25rem}
  .recipe-body{padding:14px;gap:9px}
  .recipe-body h3{font-size:1.08rem}
  .badge{font-size:.76rem;padding:6px 9px}
  .form{gap:12px}
  .form-grid{grid-template-columns:1fr;gap:11px}
  .field label{font-size:.86rem}
  .input,.textarea,.select{min-height:48px;border-radius:14px;padding:12px;font-size:16px}
  .textarea{min-height:104px}
  .multi{min-height:132px}
  .quick-capture{padding:12px;border-radius:18px}
  .quick-capture .textarea{min-height:118px}
  .btn,.iconbtn{min-height:46px}
  .ingredient-row{grid-template-columns:1fr 1fr 46px;gap:7px}
  .ingredient-row input:nth-child(3){grid-column:1/-2}
  .ingredient-row button{grid-column:auto}
  .step-row{grid-template-columns:1fr 46px;gap:7px}
  .detail-image{min-height:230px;border-radius:24px}
  .detail-title h1{font-size:clamp(1.8rem,9vw,2.6rem)}
  .detail-grid{gap:12px}
  .ingredient{grid-template-columns:58px 48px 1fr;gap:6px;font-size:.95rem}
  .step{grid-template-columns:34px 1fr;gap:8px}
  .step:before{width:30px;height:30px;border-radius:10px}
  .gallery{grid-template-columns:repeat(2,1fr)}
  .gallery img{height:108px}
  .table{display:block;overflow-x:auto;white-space:nowrap}
  .login-wrap{align-items:start;padding:18px 12px}
  .login-card{margin-top:24px}
}

@media(max-width:420px){
  .shell{padding-left:10px;padding-right:10px}
  .stats{grid-template-columns:1fr 1fr}
  .card{padding:13px}
  .recipe-img{height:148px}
  .ingredient-row{grid-template-columns:1fr}
  .ingredient-row input:nth-child(3),.ingredient-row button{grid-column:auto}
  .step-row{grid-template-columns:1fr}
  .topbar nav a{font-size:.82rem}
}
