*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
body{font-family:'Segoe UI',system-ui,sans-serif;background:#0f0f0f;color:#e0e0e0;min-height:100vh}

/* ===== HEADER ===== */
.header{background:linear-gradient(135deg,#1a1a2e,#16213e);padding:18px 20px 12px;
  border-bottom:2px solid #e94560;position:sticky;top:0;z-index:200}
.header-row{display:flex;justify-content:space-between;align-items:center;max-width:1240px;margin:0 auto}
.header-left{display:flex;align-items:center;gap:12px}
.header-logo{width:48px;height:48px;border-radius:8px;object-fit:contain;flex-shrink:0}
.header-text{display:flex;flex-direction:column}
.header h1{font-size:1.6rem;color:#e94560;letter-spacing:0.5px}
.header p{color:#555;font-size:.78rem;margin-top:2px}
.lang-toggle{display:flex;gap:2px;background:#111;border-radius:6px;padding:2px}
.lang-btn{padding:5px 12px;border:none;border-radius:5px;background:transparent;
  color:#888;font-size:.82rem;font-weight:700;cursor:pointer;transition:all .2s}
.lang-btn.active{background:#e94560;color:#fff}

/* ===== CONTAINER ===== */
.container{max-width:1240px;margin:0 auto;padding:14px 20px 40px}

/* ===== SEARCH ROW ===== */
.search-row{display:flex;gap:8px;margin-bottom:10px;align-items:stretch}
.search-area{flex:1;position:relative}
.search-inner{display:flex;flex-wrap:wrap;gap:5px;padding:8px 12px;min-height:44px;
  border:1px solid #333;border-radius:10px;background:#1a1a2e;align-items:center;
  cursor:text;transition:border-color .2s}
.search-inner.focus{border-color:#e94560}
.s-tag{display:inline-flex;align-items:center;gap:4px;padding:2px 10px;border-radius:20px;
  font-size:.78rem;font-weight:600;background:rgba(0,173,181,.15);color:#00adb5;
  border:1px solid #00adb5;white-space:nowrap}
.s-tag-x{cursor:pointer;font-size:1rem;line-height:1;margin-left:2px}
.s-tag-x:hover{color:#e94560}
#search{border:none;background:transparent;color:#e0e0e0;outline:none;
  flex:1 1 160px;font-size:.92rem;min-width:120px}
.s-dropdown{position:absolute;top:100%;left:0;right:0;max-height:200px;overflow-y:auto;
  background:#1a1a2e;border:1px solid #333;border-top:none;border-radius:0 0 8px 8px;
  z-index:120;display:none}
.s-dropdown.open{display:block}
.s-dd-label{padding:6px 14px;font-size:.7rem;color:#e94560;text-transform:uppercase;
  letter-spacing:.8px;font-weight:600;border-bottom:1px solid #222}
.s-dd-opt{padding:8px 14px;cursor:pointer;font-size:.88rem;transition:background .15s}
.s-dd-opt:hover{background:rgba(233,69,96,.12);color:#fff}
.s-dd-empty{padding:10px 14px;color:#555;font-size:.85rem;font-style:italic}

/* ===== FILTERS BUTTON ===== */
.filters-btn{padding:0 16px;border:1px solid #333;border-radius:10px;background:#1a1a2e;
  color:#aaa;font-size:.88rem;cursor:pointer;transition:all .2s;white-space:nowrap;
  display:flex;align-items:center;gap:6px}
.filters-btn:hover,.filters-btn.open{border-color:#e94560;color:#e94560}
.f-badge{background:#e94560;color:#fff;font-size:.7rem;padding:1px 6px;
  border-radius:10px;font-weight:700}

/* ===== FILTER PANEL ===== */
.filter-panel{display:none;margin-bottom:10px;padding:12px 14px;
  background:#12121e;border:1px solid #222;border-radius:10px}
.filter-panel.open{display:block}
.filters-grid{display:flex;flex-wrap:wrap;gap:10px}
.ctrl{display:flex;flex-direction:column;gap:3px;flex:1 1 150px}
.ctrl label{font-size:.68rem;color:#e94560;text-transform:uppercase;
  letter-spacing:.8px;font-weight:600}
.ctrl select{padding:8px 10px;border:1px solid #333;border-radius:7px;
  background:#1a1a2e;color:#e0e0e0;font-size:.85rem;outline:none;cursor:pointer}
.ctrl select:focus{border-color:#e94560}

/* ===== TOOLBAR ===== */
.toolbar{display:flex;justify-content:space-between;align-items:center;
  flex-wrap:wrap;gap:8px;margin-bottom:8px}
.alpha-index{display:flex;flex-wrap:wrap;gap:3px}
.a-btn{width:30px;height:28px;border-radius:5px;border:1px solid #333;background:#1a1a2e;
  color:#888;font-size:.82rem;font-weight:600;cursor:pointer;transition:all .2s;
  display:flex;align-items:center;justify-content:center}
.a-btn:hover{border-color:#e94560;color:#e94560}
.a-btn.active{background:#e94560;border-color:#e94560;color:#fff}
.a-btn.dim{opacity:.25;pointer-events:none}
.view-toggle{display:flex;gap:3px}
.v-btn{width:34px;height:28px;border-radius:5px;border:1px solid #333;background:#1a1a2e;
  color:#888;font-size:1.05rem;cursor:pointer;transition:all .2s;
  display:flex;align-items:center;justify-content:center}
.v-btn:hover{border-color:#e94560;color:#e94560}
.v-btn.active{background:#e94560;border-color:#e94560;color:#fff}

/* ===== STATS BAR ===== */
.stats-bar{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;
  gap:8px;margin-bottom:14px;padding-bottom:10px;border-bottom:1px solid #1e1e1e}
.stats-bar .count{font-size:.85rem;color:#888}
.stats-bar .count span{color:#e94560;font-weight:700}
.stats-right{display:flex;gap:6px;align-items:center}
.stats-right select{padding:6px 10px;border:1px solid #333;border-radius:6px;
  background:#1a1a2e;color:#e0e0e0;font-size:.82rem;outline:none;cursor:pointer}
.btn-reset{padding:6px 14px;background:transparent;border:1px solid #e94560;color:#e94560;
  border-radius:6px;cursor:pointer;font-size:.8rem;transition:all .2s;white-space:nowrap}
.btn-reset:hover{background:#e94560;color:#fff}

/* ===== GRID ===== */
.c-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(310px,1fr));gap:16px}
.c-grid.view-list{grid-template-columns:1fr;gap:6px}

/* ===== CARD FLIP (GRID) ===== */
.card-wrap{perspective:1000px;height:420px}
.card-flip{position:relative;width:100%;height:100%;transition:transform .6s;transform-style:preserve-3d}
@media(hover:hover){.c-grid:not(.view-list) .card-wrap:hover .card-flip{transform:rotateY(180deg)}}
.card-wrap.flipped .card-flip{transform:rotateY(180deg)}
.face{position:absolute;top:0;left:0;width:100%;height:100%;backface-visibility:hidden;
  border-radius:12px;overflow:hidden;display:flex;flex-direction:column}

/* ===== FRONT FACE WITH IMAGE ===== */
.face.front{
  border:1px solid #222;
  transition:border-color .2s;
  background-color:#1a1a2e;
  background-size:60%;
  background-repeat:no-repeat;
  background-position:center center; // here
}
.card-wrap:hover .face.front{border-color:#e94560}

/* transparent overlay */
.front-overlay{
  position:absolute;top:0;left:0;width:100%;height:100%;
  background:transparent;
  display:flex;flex-direction:column;
  padding:16px;overflow-y:auto;
}
/* Semi-transparent panel behind ingredients */
.ing-panel{
  margin-top:auto;
  background:rgba(15,15,25, 0.30); // here
  border-radius:10px;
  padding:10px 12px;
  backdrop-filter:blur(0px); // here
  -webkit-backdrop-filter:blur(6px);
}

/* Adjust header & list inside panel */
.ing-panel .ing-hdr{margin-bottom:5px}
.ing-panel .ing-list li{border-bottom-color:rgba(255,255,255,.06)}

/* Stronger text-shadows for elements over the image */
.front-overlay .c-title{text-shadow:0 2px 12px rgba(0,0,0,.9), 0 0 4px rgba(0,0,0,.7)}
.front-overlay .c-sub{text-shadow:0 1px 8px rgba(0,0,0,.9)}
.front-overlay .c-meta span{text-shadow:0 1px 6px rgba(0,0,0,.8)}
.front-overlay .badge{box-shadow:0 1px 6px rgba(0,0,0,.5)}
.front-overlay .flip-hint{text-shadow:0 1px 4px rgba(0,0,0,.8)}

/* ===== BACK FACE ===== */
.face.back{transform:rotateY(180deg);
  background:linear-gradient(180deg,#16213e,#1a1a2e);
  border:1px solid #e94560;padding:18px;overflow-y:auto}

/* ===== CARD CONTENT ===== */
.c-head{margin-bottom:6px}
.c-title{font-size:1.15rem;font-weight:700;color:#fff;line-height:1.2;
  text-shadow:0 2px 8px rgba(0,0,0,.6)}
.c-sub{font-size:.8rem;color:#888;margin-top:1px;
  text-shadow:0 1px 4px rgba(0,0,0,.5)}
.c-meta{display:flex;gap:8px;font-size:.72rem;color:#888;margin-bottom:8px;flex-wrap:wrap}
.c-meta span{color:#bbb;text-shadow:0 1px 3px rgba(0,0,0,.4)}
.badges{display:flex;flex-wrap:wrap;gap:4px;margin-bottom:10px}
.badge{font-size:.66rem;padding:2px 7px;border-radius:20px;font-weight:600;
  text-transform:uppercase;letter-spacing:.4px;white-space:nowrap}
.b-iba{background:rgba(233,69,96,.2);color:#e94560;border:1px solid #e94560}
.b-base{background:rgba(0,173,181,.2);color:#00adb5;border:1px solid #00adb5}
.b-d-low{background:rgba(76,175,80,.2);color:#66bb6a;border:1px solid #66bb6a}
.b-d-medium{background:rgba(255,183,77,.2);color:#ffb74d;border:1px solid #ffb74d}
.b-d-high{background:rgba(239,83,80,.2);color:#ef5350;border:1px solid #ef5350}

.ing-hdr{font-size:.7rem;color:#e94560;text-transform:uppercase;letter-spacing:.8px;
  margin-bottom:4px;font-weight:600;margin-top:auto}
.ing-list{list-style:none;flex-grow:0}
.ing-list li{padding:3px 0;font-size:.85rem;color:#ccc;display:flex;
  justify-content:space-between;border-bottom:1px solid rgba(255,255,255,.05)}
.ing-list li:last-child{border-bottom:none}
.ing-a{color:#777;white-space:nowrap;margin-left:8px}

/* ===== CARD BACK CONTENT ===== */
.back-name{font-size:1.1rem;font-weight:700;color:#e94560;margin-bottom:2px}
.back-sub{font-size:.78rem;color:#555;margin-bottom:14px}
.back-lbl{font-size:.7rem;color:#00adb5;text-transform:uppercase;letter-spacing:1px;
  font-weight:600;margin-bottom:8px}
.steps-ol{padding-left:20px;flex:1}
.steps-ol li{font-size:.88rem;color:#ccc;line-height:1.55;margin-bottom:8px;padding-left:4px}
.steps-ol li::marker{color:#e94560;font-weight:700}

/* Recipe link button */
.recipe-link{
  display:inline-flex;align-items:center;gap:5px;
  position:absolute;bottom:14px;right:14px;
  padding:6px 14px;
  background:rgba(233,69,96,.15);
  border:1px solid #e94560;
  border-radius:20px;
  color:#e94560;
  font-size:.76rem;
  font-weight:600;
  text-decoration:none;
  text-transform:uppercase;
  letter-spacing:.5px;
  transition:all .25s;
  z-index:10;
}
.recipe-link:hover{
  background:#e94560;
  color:#fff;
  transform:scale(1.05);
}
.recipe-link .arrow{
  font-size:.9rem;
  transition:transform .25s;
}
.recipe-link:hover .arrow{
  transform:translateX(3px);
}

/* Ensure back face has relative positioning for the link */
.face.back{position:relative;padding-bottom:50px}

/* List view recipe link */
.list-recipe-link{
  display:inline-flex;align-items:center;gap:5px;
  margin-top:10px;
  padding:6px 14px;
  background:rgba(233,69,96,.1);
  border:1px solid #e94560;
  border-radius:20px;
  color:#e94560;
  font-size:.76rem;
  font-weight:600;
  text-decoration:none;
  text-transform:uppercase;
  letter-spacing:.5px;
  transition:all .25s;
}
.list-recipe-link:hover{
  background:#e94560;
  color:#fff;
}

/* Prevent card flip when clicking the recipe link */
.recipe-link{pointer-events:auto}

/* ===== FLIP HINT ===== */
.flip-hint{position:absolute;bottom:8px;right:12px;font-size:.68rem;color:#555;
  pointer-events:none;transition:opacity .3s}
.card-wrap:hover .flip-hint{opacity:0}

/* ===== LIST CARD ===== */
.list-card{background:#1a1a2e;border:1px solid #222;border-radius:10px;
  transition:border-color .2s;overflow:hidden}
.list-card:hover{border-color:#e94560}
.list-summary{display:flex;align-items:center;gap:12px;padding:12px 16px;cursor:pointer;flex-wrap:wrap}
.list-thumb{width:44px;height:44px;border-radius:8px;background-color:#111;
  background-size:contain;background-repeat:no-repeat;background-position:center;flex-shrink:0}
.list-name{min-width:160px;flex-shrink:0}
.list-name .c-title{font-size:1.05rem;text-shadow:none}
.list-name .c-sub{font-size:.75rem;text-shadow:none}
.list-badges{display:flex;flex-wrap:wrap;gap:4px;flex:1}
.list-meta-text{font-size:.75rem;color:#666;white-space:nowrap}
.expand-icon{font-size:1.1rem;color:#666;transition:transform .3s;margin-left:auto;flex-shrink:0}
.list-card.expanded .expand-icon{transform:rotate(180deg);color:#e94560}
.list-details{display:none;padding:0 16px 14px;border-top:1px solid #222}
.list-card.expanded .list-details{display:flex;gap:20px;flex-wrap:wrap;padding-top:12px}
.ld-col{flex:1 1 250px}
.ld-col h4{font-size:.72rem;color:#e94560;text-transform:uppercase;letter-spacing:.8px;
  font-weight:600;margin-bottom:6px}
.ld-col ul{list-style:none;padding-left:0}
.ld-col ul li{font-size:.85rem;color:#ccc;padding:2px 0;display:flex;justify-content:space-between}
.ld-col ol{padding-left:18px}
.ld-col ol li{font-size:.85rem;color:#ccc;line-height:1.5;margin-bottom:4px}
.ld-col ol li::marker{color:#e94560;font-weight:600}

/* ===== EMPTY / LOAD MORE ===== */
.empty-state{grid-column:1/-1;text-align:center;padding:50px 20px;color:#444}
.empty-state .icon{font-size:2.5rem;margin-bottom:8px}
.lm-wrap{text-align:center;margin-top:18px}
.btn-more{padding:10px 28px;background:#1a1a2e;border:1px solid #e94560;color:#e94560;
  border-radius:8px;cursor:pointer;font-size:.88rem;transition:all .2s}
.btn-more:hover{background:#e94560;color:#fff}

/* ===== ANIMATION ===== */
@keyframes cardIn{from{opacity:0;transform:translateY(14px)}to{opacity:1;transform:translateY(0)}}
.card-wrap,.list-card{animation:cardIn .35s ease-out both}

/* ===== SCROLLBAR ===== */
::-webkit-scrollbar{width:5px}::-webkit-scrollbar-track{background:#111}
::-webkit-scrollbar-thumb{background:#333;border-radius:3px}

/* ===== NO-IMAGE FALLBACK ===== */
.face.front.no-img{background-image:none !important}
.no-img .front-overlay{
  background:rgba(26,26,46,0.98);
}

/* ===== FOOTER ===== */
.footer{
  border-top:1px solid #1e1e1e;
  padding:16px 20px;
  text-align:center;
}
.footer-content{
  max-width:1240px;
  margin:0 auto;
  font-size:.75rem;
  color:#555;
}
.footer-content a{
  color:#888;
  text-decoration:none;
  transition:color .2s;
}
.footer-content a:hover{
  color:#e94560;
}
.footer-sep{
  margin:0 8px;
  color:#333;
}

/* ===== RESPONSIVE ===== */
@media(max-width:700px){
  .header h1{font-size:1.2rem}
  .c-grid,.c-grid.view-list{grid-template-columns:1fr}
  .ctrl{flex:1 1 100%}
  .search-row{flex-direction:column}
  .list-summary{flex-direction:column;align-items:flex-start;gap:6px}
  .list-name{min-width:auto}
  .card-wrap{height:400px}
}