:root{
  --bg:#F5F0E8;
  --card:#ffffff;
  --text:#111827;
  --muted:#6B7280;
  --border:#E5E7EB;
  --accent:#F2994A;
  --shadow:0 10px 30px rgba(17,24,39,.08);
  --radius:16px;
  --container:1200px;
}

html.panpal-dark{
  --bg:#0B0F14;
  --card:#111827;
  --text:#F9FAFB;
  --muted:#9CA3AF;
  --border:#1F2937;
  --accent:#F2994A;
  --shadow:0 10px 30px rgba(0,0,0,.40);
}

*{box-sizing:border-box}
body{
  margin:0;
  font-family: 'Inter', system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
  color:var(--text);
  background:var(--bg) url('../img/paper-bg.webp') repeat;
  line-height:1.55;
  position:relative;
}

.pp-header,.pp-main,.pp-footer{position:relative; z-index:1;}

a{color:inherit; text-decoration:none}
a:hover{color:var(--accent)}
img{max-width:100%; height:auto; display:block}

.pp-container{
  max-width:var(--container);
  margin:0 auto;
  padding:0 20px;
}

.pp-header{
  padding:18px 0 8px;
}

.pp-header-row{
  display:flex;
  align-items:center;
  gap:16px;
  justify-content:space-between;
}

.pp-brand{
  display:flex;
  align-items:center;
  gap:12px;
  min-width:180px;
}
.pp-logo-link{display:flex; align-items:center;}
.pp-logo{height:44px; width:auto; border-radius:12px;}
.pp-brand .pp-logo-slot{display:none;}

.pp-nav ul{
  list-style:none;
  display:flex;
  gap:16px;
  padding:0;
  margin:0;
  flex-wrap:wrap;
}
.pp-nav a{
  padding:10px 10px;
  border-bottom:2px solid transparent;
  color:var(--muted);
}
.pp-nav .current-menu-item > a,
.pp-nav a:hover{
  border-bottom-color:var(--accent);
  color:var(--text);
}

.pp-tools{
  display:flex;
  gap:10px;
  align-items:center;
}

.pp-btn{
  border:1px solid var(--border);
  background:transparent;
  border-radius:12px;
  padding:10px 12px;
  cursor:pointer;
  color:var(--text);
}
.pp-btn:hover{border-color:var(--accent)}

.pp-lang{
  border:1px solid var(--border);
  border-radius:12px;
  padding:10px 12px;
  color:var(--muted);
}

.pp-ads-slot{
  margin:10px 0 14px;
  border:1px dashed var(--border);
  border-radius:12px;
  padding:10px;
  background:rgba(255,255,255,.04);
}
.pp-ads-slot .widget{margin:0}
.pp-ads-placeholder{
  color:var(--muted);
  font-size:12px;
  text-align:center;
  padding:6px 0;
}

.pp-search{
  margin:12px 0 6px;
}
.pp-search form{
  display:flex;
  gap:10px;
  align-items:center;
  background:var(--card);
  border:1px solid var(--border);
  border-radius:999px;
  padding:10px 12px;
  box-shadow:var(--shadow);
}
.pp-search input[type="search"]{
  border:0;
  outline:0;
  flex:1;
  font-size:16px;
  background:transparent;
  color:var(--text);
}
.pp-search button{
  border:0;
  background:var(--accent);
  color:#111;
  border-radius:999px;
  padding:10px 14px;
  cursor:pointer;
  font-weight:600;
}

.pp-section{
  padding:18px 0 10px;
}

.pp-section-title{
  text-align:center;
  font-size:26px;
  margin:8px 0 14px;
}

.pp-chips{
  display:flex;
  gap:10px;
  flex-wrap:wrap;
  justify-content:center;
}
.pp-chip{
  display:inline-flex;
  padding:10px 14px;
  border-radius:999px;
  background:var(--card);
  border:1px solid var(--border);
  color:var(--text);
}
.pp-chip:hover{
  border-color:var(--accent);
  transform:translateY(-1px);
}

.pp-grid{
  display:grid;
  grid-template-columns:1fr;
  gap:16px;
}

@media (min-width: 720px){
  .pp-grid{grid-template-columns:repeat(2, 1fr)}
}
@media (min-width: 1024px){
  .pp-grid{grid-template-columns:repeat(3, 1fr)}
}

.pp-card{
  background:var(--card);
  border:1px solid var(--border);
  border-radius:var(--radius);
  overflow:hidden;
  box-shadow:var(--shadow);
  transition:transform .12s ease, box-shadow .12s ease, border-color .12s ease;
  height:100%;
}
.pp-card:hover{
  transform:translateY(-2px);
  border-color:rgba(242,153,74,.55);
}
.pp-card .pp-thumb{
  aspect-ratio:16/9;
  background:rgba(0,0,0,.05);
}
.pp-card .pp-thumb img{
  width:100%;
  height:100%;
  object-fit:cover;
}
.pp-card .pp-card-body{
  padding:14px 14px 12px;
}
.pp-card h3{
  font-size:18px;
  line-height:1.2;
  margin:0 0 8px;
}
.pp-card .pp-excerpt{
  color:var(--muted);
  font-size:14px;
  margin:0 0 10px;
  display:-webkit-box;
  -webkit-line-clamp:2;
  -webkit-box-orient:vertical;
  overflow:hidden;
}
.pp-meta{
  display:flex;
  gap:12px;
  color:var(--muted);
  font-size:12px;
  align-items:center;
  flex-wrap:wrap;
}
.pp-meta b{color:var(--text)}

.pp-pagination{
  margin:24px 0 8px;
  display:flex;
  justify-content:center;
}
.pp-pagination .page-numbers{
  display:inline-flex;
  gap:8px;
  flex-wrap:wrap;
}
.pp-pagination a, .pp-pagination span{
  padding:10px 12px;
  border:1px solid var(--border);
  border-radius:12px;
  background:var(--card);
  color:var(--text);
}
.pp-pagination .current{
  border-color:var(--accent);
}

.pp-filters{
  margin:14px 0 18px;
  background:var(--card);
  border:1px solid var(--border);
  border-radius:18px;
  padding:14px;
  box-shadow:var(--shadow);
}
.pp-filters form{
  display:grid;
  grid-template-columns:1fr;
  gap:12px;
}
@media (min-width: 720px){
  .pp-filters form{grid-template-columns:repeat(2, 1fr)}
}
@media (min-width: 1024px){
  .pp-filters form{grid-template-columns:repeat(4, 1fr)}
}
.pp-field label{
  display:block;
  font-size:12px;
  color:var(--muted);
  margin:0 0 6px;
}
.pp-field input, .pp-field select{
  width:100%;
  padding:10px 12px;
  border:1px solid var(--border);
  border-radius:12px;
  background:transparent;
  color:var(--text);
  outline:0;
}
.pp-field input:focus, .pp-field select:focus{border-color:var(--accent)}
.pp-filters .pp-actions{
  grid-column:1/-1;
  display:flex;
  gap:10px;
  justify-content:flex-end;
  flex-wrap:wrap;
}
.pp-filters .pp-actions button,
.pp-filters .pp-actions a{
  padding:10px 12px;
  border-radius:12px;
  border:1px solid var(--border);
  background:transparent;
}
.pp-filters .pp-actions button{
  background:var(--accent);
  border-color:rgba(0,0,0,.12);
  font-weight:700;
}
.pp-filters .pp-actions a:hover{border-color:var(--accent)}

.pp-footer{
  margin-top:30px;
  padding:22px 0;
  border-top:1px solid var(--border);
  color:var(--muted);
  font-size:14px;
}
.pp-footer .pp-footer-row{
  display:flex;
  gap:12px;
  align-items:center;
  justify-content:space-between;
  flex-wrap:wrap;
}


/* Category cards (home + archives) */
.pp-catgrid{
  display:grid;
  grid-template-columns:repeat(2, 1fr);
  gap:12px;
  margin: 0 0 16px;
}
@media (min-width: 720px){
  .pp-catgrid{grid-template-columns:repeat(4, 1fr);}
}
@media (min-width: 1024px){
  .pp-catgrid{grid-template-columns:repeat(6, 1fr);}
}
.pp-catcard{
  display:flex;
  align-items:center;
  gap:10px;
  padding:10px;
  text-decoration:none;
}
.pp-catcard .pp-catimg{
  width:42px;
  height:42px;
  border-radius:12px;
  overflow:hidden;
  flex:0 0 auto;
  background:rgba(0,0,0,.05);
}
.pp-catcard .pp-catimg img{
  width:100%;
  height:100%;
  object-fit:cover;
  display:block;
}
.pp-catcard .pp-catmeta{
  min-width:0;
}
.pp-catcard .pp-cattitle{
  font-weight:700;
  line-height:1.1;
  font-size:13px;
  color:var(--text);
  margin:0;
}
.pp-catcard .pp-catdesc{
  margin:2px 0 0;
  font-size:12px;
  color:var(--muted);
  line-height:1.2;
  overflow:hidden;
  display:-webkit-box;
  -webkit-line-clamp:2;
  -webkit-box-orient:vertical;
}

/* Recipe page (TZ §6) */
.pp-breadcrumbs{font-size:14px;color:var(--muted);display:flex;flex-wrap:wrap;gap:6px;align-items:center;margin:10px 0 18px}
.pp-breadcrumbs a{color:inherit;text-decoration:none}
.pp-breadcrumbs a:hover{text-decoration:underline}
.pp-bc-sep{opacity:.6}
.pp-bc-current{color:var(--text)}

.pp-recipe-title{font-size:42px;line-height:1.1;margin:0 0 14px}
.pp-recipe-hero{border-radius:18px;overflow:hidden;background:var(--card);border:1px solid var(--border);box-shadow:var(--shadow);position:relative}
.pp-recipe-hero-img{width:100%;height:auto;display:block}

.pp-recipe-stats{display:grid;grid-template-columns:repeat(5,1fr);gap:0;margin:-22px 0 14px;padding:10px 10px;background:rgba(255,255,255,.86);border:1px solid rgba(17,24,39,.10);border-radius:16px;box-shadow:0 18px 38px rgba(17,24,39,.14);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);position:relative;z-index:2}
.pp-stat{display:flex;gap:10px;align-items:center;padding:10px 12px;border-radius:12px;background:transparent;border:0;border-right:1px solid rgba(17,24,39,.10)}.pp-stat:last-child{border-right:0}
.pp-stat-ico{width:34px;height:34px;display:flex;align-items:center;justify-content:center;border-radius:12px;background:rgba(17,24,39,.06);border:1px solid rgba(17,24,39,.10);font-size:16px}
.pp-stat-label{font-size:12px;color:var(--muted);line-height:1.1}
.pp-stat-val{font-weight:700}
html.panpal-dark .pp-recipe-stats{background:rgba(17,24,39,.62);border-color:rgba(255,255,255,.12);box-shadow:0 18px 38px rgba(0,0,0,.38)}
html.panpal-dark .pp-stat{border-right-color:rgba(255,255,255,.10)}
html.panpal-dark .pp-stat-ico{background:rgba(255,255,255,.06);border-color:rgba(255,255,255,.12)}


.pp-recipe-desc{margin:10px 0 10px;color:var(--text);max-width:75ch}

.pp-share{display:flex;gap:8px;margin:8px 0 0}
.pp-share-btn{width:34px;height:34px;border-radius:10px;display:flex;align-items:center;justify-content:center;text-decoration:none;background:var(--card);border:1px solid var(--border);color:var(--text)}
.pp-share-btn:hover{background:rgba(255,255,255,.07)}

.pp-recipe-grid{display:grid;grid-template-columns:1.05fr 1.35fr .85fr;gap:22px;margin:18px 0 0;align-items:start}
.pp-recipe-card{padding:18px}
.pp-card-hd{padding:14px 14px 0}
.pp-card-bd{padding:0 14px 14px}
.pp-card.pp-card-nut .pp-card-bd{padding-top:6px}
.pp-card.pp-card-sim .pp-card-bd{padding-top:6px}

.pp-card-title{margin:0 0 12px;font-size:20px}

.pp-ing-media{margin:0 0 12px;border-radius:14px;overflow:hidden;aspect-ratio:16/9;border:1px solid var(--border);background:rgba(0,0,0,.03)}
.pp-ing-img{width:100%;height:100%;object-fit:cover;display:block}

.pp-ing{margin:0;padding:0;list-style:none;display:flex;flex-direction:column;gap:10px}
.pp-ing li{display:flex;gap:10px;align-items:flex-start}
.pp-ing-dot{opacity:.7;line-height:1.2}

.pp-steps{margin:0;padding:0;list-style:none;display:flex;flex-direction:column;gap:14px}
.pp-step{display:flex;gap:12px;align-items:flex-start}
.pp-step-badge{flex:0 0 28px;width:28px;height:28px;border-radius:999px;display:flex;align-items:center;justify-content:center;background:rgba(17,24,39,.06);border:1px solid var(--border);font-weight:800}
.pp-step-text{line-height:1.55}

.pp-bullets{margin:0;padding-left:18px;display:flex;flex-direction:column;gap:8px}
.pp-muted{color:var(--muted);margin:0}

.pp-funfact{font-size:14px;line-height:1.6;color:var(--text)}
.pp-funfact strong{display:block;margin:0 0 6px}

.pp-faq details{border-top:1px solid var(--border);padding:10px 0}
.pp-faq details:first-child{border-top:none}
.pp-faq summary{cursor:pointer;font-weight:700}
.pp-faq-a{margin-top:8px;color:var(--muted)}

.pp-nutri{width:100%;border-collapse:collapse}
.pp-nutri th,.pp-nutri td{padding:8px 0;border-bottom:1px solid var(--border);font-size:14px}
.pp-nutri th{text-align:left;color:var(--muted);font-weight:600}
.pp-nutri td{text-align:right}

.pp-sim-list{display:flex;flex-direction:column;gap:12px}
.pp-sim{display:grid;grid-template-columns:88px 1fr;gap:12px;align-items:center;text-decoration:none;color:inherit}
.pp-sim-thumb{width:88px;height:64px;border-radius:12px;overflow:hidden;background:rgba(0,0,0,.03);border:1px solid var(--border)}
.pp-sim-thumb img{width:100%;height:100%;object-fit:cover;display:block}
.pp-sim-title{font-weight:700}

.pp-recipe-extras{grid-column:1 / -1;display:flex;flex-direction:column;gap:14px;margin-top:2px}

@media (max-width: 980px){
  .pp-recipe-stats{grid-template-columns:repeat(2,1fr);gap:10px;margin:-18px 0 14px}
  .pp-stat{border-right:0;border:1px solid rgba(17,24,39,.10);background:rgba(255,255,255,.86)}
  .pp-stat:last-child{border-right:0}
  .pp-recipe-grid{grid-template-columns:1fr}
  .pp-recipe-title{font-size:34px}
}

.pp-share-btn svg{width:16px;height:16px;display:block}

/* Subtle checker pattern like the reference */
.pp-main-recipe{background-image:radial-gradient(circle at 1px 1px, rgba(17,24,39,.06) 1px, transparent 0),radial-gradient(circle at 9px 9px, rgba(17,24,39,.03) 1px, transparent 0);background-size:18px 18px;background-position:0 0,0 0}
html.panpal-dark .pp-main-recipe{background-image:none}

.pp-recipe-mini{margin:10px 0 0;color:var(--muted);font-size:13px;display:flex;gap:12px;flex-wrap:wrap}
.pp-recipe-mini b{color:var(--text);font-weight:700}

/* =====================
   Recipe prototype (v0.4.2)
   ===================== */

.pp-main-recipe{padding:12px 0 32px;}

.pp-recipe-head{margin-top:6px;}
.pp-recipe-toprow{display:flex; align-items:flex-end; justify-content:space-between; gap:16px; flex-wrap:wrap;}
.pp-recipe-title{margin:8px 0 6px; font-size:44px; line-height:1.05; letter-spacing:-0.02em; font-family: 'Playfair Display', ui-serif, Georgia, 'Times New Roman', Times, serif;}

.pp-recipe-topchips{display:flex; gap:10px; flex-wrap:wrap; justify-content:flex-end;}
.pp-topchip{display:inline-flex; align-items:center; padding:8px 12px; border-radius:999px; border:1px solid rgba(17,24,39,.10); background:rgba(255,255,255,.55); color:rgba(17,24,39,.75); box-shadow:0 6px 20px rgba(17,24,39,.06);}
html.panpal-dark .pp-topchip{background:rgba(17,24,39,.50); border-color:rgba(255,255,255,.10); color:rgba(255,255,255,.78);}

.pp-recipe-hero{margin:10px 0 14px; border-radius:22px; overflow:hidden; box-shadow:0 16px 42px rgba(17,24,39,.14);}
.pp-recipe-hero-img{width:100%; height:auto; max-height:460px; object-fit:cover;}

.pp-statbar{display:flex; gap:12px; flex-wrap:wrap; padding:12px; border-radius:22px; border:1px solid rgba(17,24,39,.10); background:rgba(255,255,255,.62); box-shadow:0 10px 32px rgba(17,24,39,.08);}
html.panpal-dark .pp-statbar{background:rgba(17,24,39,.55); border-color:rgba(255,255,255,.10);}

.pp-statbar-item{display:flex; align-items:center; gap:12px; padding:12px 14px; border-radius:20px; background:rgba(255,255,255,.72); border:1px solid rgba(17,24,39,.08); min-width:210px;}
html.panpal-dark .pp-statbar-item{background:rgba(11,15,20,.35); border-color:rgba(255,255,255,.08);}

.pp-ico{width:18px; height:18px; display:block;}

.pp-ico-wrap{width:30px; height:30px; display:inline-flex; align-items:center; justify-content:center; border-radius:999px; background:rgba(17,24,39,.06); border:1px solid rgba(17,24,39,.10);}
html.panpal-dark .pp-ico-wrap{background:rgba(255,255,255,.08); border-color:rgba(255,255,255,.10);}

.pp-stat-label{font-size:12px; font-weight:500; color:rgba(17,24,39,.58); line-height:1.15;}
html.panpal-dark .pp-stat-label{color:rgba(255,255,255,.70);}

.pp-stat-val{font-weight:800; font-size:15px; letter-spacing:-0.01em; font-variant-numeric: tabular-nums;}

.pp-recipe-desc{margin:12px 0 10px; max-width:860px; color:rgba(17,24,39,.82);}
html.panpal-dark .pp-recipe-desc{color:rgba(255,255,255,.78);}

.pp-share{display:flex; gap:10px; margin:10px 0 10px;}
.pp-share-btn{width:34px; height:34px; display:inline-flex; align-items:center; justify-content:center; border-radius:999px; border:1px solid rgba(17,24,39,.12); background:rgba(255,255,255,.62); box-shadow:0 10px 24px rgba(17,24,39,.08);} 
.pp-share-btn .pp-ico{width:16px; height:16px; opacity:.92;}
html.panpal-dark .pp-share-btn{background:rgba(17,24,39,.55); border-color:rgba(255,255,255,.10);} 
html.panpal-dark .pp-share-btn .pp-ico{opacity:.85;}

.pp-meta-chips{display:flex; flex-wrap:wrap; gap:10px; margin:10px 0 2px;}
.pp-mchip{display:inline-flex; align-items:center; gap:10px; padding:10px 14px; border-radius:999px; border:1px solid rgba(17,24,39,.10); background:rgba(255,255,255,.62); color:rgba(17,24,39,.82);}
.pp-mchip-ico{display:inline-flex; align-items:center; justify-content:center;}
.pp-mchip-ico .pp-ico{width:16px; height:16px; opacity:.88;}
.pp-mchip-label{font-weight:700; color:rgba(17,24,39,.82); font-size:13px; letter-spacing:-0.01em;}
.pp-mchip-val{color:rgba(17,24,39,.78); font-size:13px;}

html.panpal-dark .pp-mchip{background:rgba(17,24,39,.55); border-color:rgba(255,255,255,.10); color:rgba(255,255,255,.86);} 
html.panpal-dark .pp-mchip-label{color:rgba(255,255,255,.90);} 
html.panpal-dark .pp-mchip-val{color:rgba(255,255,255,.78);} 

.pp-glass{background:rgba(255,255,255,.55); backdrop-filter: blur(10px); -webkit-backdrop-filter: blur(10px);} 
html.panpal-dark .pp-glass{background:rgba(17,24,39,.55);} 

.pp-recipe-layout{display:grid; grid-template-columns:1fr; gap:18px; margin-top:16px; align-items:start;}
@media (min-width: 960px){
  .pp-recipe-layout{grid-template-columns: 1.05fr 0.95fr 0.62fr;}
}

.pp-recipe-card .pp-card-title{font-size:18px; margin:0 0 12px; padding:14px 16px 0; font-weight:800;}
.pp-recipe-card{padding-bottom:14px;}

.pp-ing-media{margin:0 16px 12px; border-radius:16px; overflow:hidden; border:1px solid rgba(17,24,39,.10);} 
html.panpal-dark .pp-ing-media{border-color:rgba(255,255,255,.10);} 
.pp-ing-img{width:100%; height:auto; display:block;}

.pp-ing{list-style:none; margin:0; padding:0 16px;}
.pp-ing li{padding:6px 0; border-bottom:1px solid rgba(17,24,39,.08); color:rgba(17,24,39,.80);} 
.pp-ing li:last-child{border-bottom:0;}
html.panpal-dark .pp-ing li{border-bottom-color:rgba(255,255,255,.08); color:rgba(255,255,255,.78);} 

.pp-steps{list-style:none; margin:0; padding:0 16px; counter-reset: step;}
.pp-step{position:relative; display:flex; gap:12px; padding:10px 0 10px 0; border-bottom:1px solid rgba(17,24,39,.08);} 
.pp-step:last-child{border-bottom:0;}
.pp-step::before{content:""; position:absolute; left:14px; top:0; bottom:0; width:2px; background:rgba(17,24,39,.10);} 
.pp-step:first-child::before{top:20px;} 
.pp-step:last-child::before{bottom:20px;} 
html.panpal-dark .pp-step{border-bottom-color:rgba(255,255,255,.08);} 
html.panpal-dark .pp-step::before{background:rgba(255,255,255,.12);} 

.pp-step-badge{flex:0 0 auto; width:28px; height:28px; border-radius:999px; display:inline-flex; align-items:center; justify-content:center; font-weight:800; font-size:13px; background:rgba(242,153,74,.20); color:#7a3b05; border:1px solid rgba(242,153,74,.40); margin-left:2px; margin-top:2px;}
html.panpal-dark .pp-step-badge{color:#f9fafb; background:rgba(242,153,74,.18); border-color:rgba(242,153,74,.35);} 
.pp-step-text{color:rgba(17,24,39,.80);} 
html.panpal-dark .pp-step-text{color:rgba(255,255,255,.78);} 

.pp-recipe-side{display:flex; flex-direction:column; gap:16px;}
.pp-side-card{padding:14px 16px;}
.pp-side-card .pp-card-title{margin:0 0 10px; padding:0; font-size:18px; font-weight:800;}

.pp-nutri{width:100%; border-collapse:collapse;}
.pp-nutri th{font-size:13px; text-align:left; color:var(--muted); padding:6px 0; font-weight:700;}
.pp-nutri td{font-size:13px; text-align:right; padding:6px 0; font-weight:700;}

.pp-funfact{font-size:13px; color:rgba(17,24,39,.80);} 
.pp-funfact strong{display:block; margin-bottom:6px; font-size:12px; letter-spacing:.02em; text-transform:uppercase; color:rgba(17,24,39,.55);} 
html.panpal-dark .pp-funfact{color:rgba(255,255,255,.78);} 
html.panpal-dark .pp-funfact strong{color:rgba(255,255,255,.55);} 

.pp-sim-list{display:flex; flex-direction:column; gap:12px;}
.pp-sim{display:grid; grid-template-columns:84px 1fr; gap:12px; align-items:center;}
.pp-sim-thumb{width:84px; height:64px; border-radius:14px; overflow:hidden; border:1px solid rgba(17,24,39,.10);} 
.pp-sim-thumb img{width:100%; height:100%; object-fit:cover;}
html.panpal-dark .pp-sim-thumb{border-color:rgba(255,255,255,.10);} 
.pp-sim-title{font-weight:800; font-size:13px; color:rgba(17,24,39,.85);} 
html.panpal-dark .pp-sim-title{color:rgba(255,255,255,.85);} 

.pp-bullets{margin:0; padding-left:18px; color:rgba(17,24,39,.80);} 
html.panpal-dark .pp-bullets{color:rgba(255,255,255,.78);} 
.pp-bullets li{margin:6px 0;}

.pp-faq details{border-top:1px solid rgba(17,24,39,.10); padding:10px 0;}
.pp-faq details:first-child{border-top:0; padding-top:0;}
html.panpal-dark .pp-faq details{border-top-color:rgba(255,255,255,.10);} 
.pp-faq summary{cursor:pointer; font-weight:800; color:rgba(17,24,39,.85);} 
html.panpal-dark .pp-faq summary{color:rgba(255,255,255,.85);} 
.pp-faq-a{margin-top:8px; color:rgba(17,24,39,.75);} 
html.panpal-dark .pp-faq-a{color:rgba(255,255,255,.75);} 

@media (max-width: 560px){
  .pp-recipe-title{font-size:34px;}
  .pp-statbar-item{min-width:160px;}
}

html.panpal-dark body{background:var(--bg);}


/* Language dropdown */
.pp-lang{position:relative;}
.pp-lang-btn{
  display:flex;align-items:center;gap:8px;
  border:1px solid var(--border);
  border-radius:12px;
  padding:10px 12px;
  background:rgba(255,255,255,0.6);
  cursor:pointer;
  color:var(--text);
  line-height:1;
}
.panpal-dark .pp-lang-btn{background:rgba(0,0,0,0.25)}
.pp-lang-btn:hover{border-color:var(--accent)}
.pp-lang-flag{width:18px;height:12px;object-fit:cover;border-radius:3px;box-shadow:0 0 0 1px rgba(0,0,0,0.08)}
.pp-lang-code{font-weight:700;font-size:12px;letter-spacing:0.4px}
.pp-lang-chevron{margin-left:2px;opacity:0.75}
.pp-lang-menu{
  display:none;
  position:absolute;right:0;top:calc(100% + 8px);
  min-width:220px;
  border:1px solid var(--border);
  border-radius:14px;
  background:var(--card);
  box-shadow:0 12px 40px rgba(0,0,0,0.12);
  padding:8px;
  z-index:1000;
}
.pp-lang.is-open .pp-lang-menu{display:block}
.pp-lang-item{
  display:flex;align-items:center;gap:10px;
  padding:10px 10px;
  border-radius:10px;
  text-decoration:none;
  color:var(--text);
}
.pp-lang-item:hover{background:rgba(0,0,0,0.04)}
.panpal-dark .pp-lang-item:hover{background:rgba(255,255,255,0.06)}
.pp-lang-item.is-current{outline:2px solid rgba(215,144,86,0.35)}
.pp-lang-name{opacity:0.75;font-size:12px}


/* Rating stars */
.pp-rating{margin:10px 0 12px}
.pp-stars{position:relative;display:inline-block;font-size:18px;letter-spacing:2px;line-height:1}
.pp-stars::before{content:'★★★★★';color:rgba(0,0,0,0.18)}
.panpal-dark .pp-stars::before{color:rgba(255,255,255,0.25)}
.pp-stars-fill{position:absolute;left:0;top:0;overflow:hidden;white-space:nowrap;height:100%}
.pp-stars-fill::before{content:'★★★★★';color:#D79056}
.pp-rating-text{margin-top:6px;color:var(--muted);font-size:12px}

/* ===== PanPal v0.4.6 – recipe page polish closer to reference ===== */
:root{
  --pp-paper: url('../img/paper-bg.webp');
}

/* Paper background without dotted pattern */
.pp-main-recipe{
  background: var(--bg) var(--pp-paper) repeat !important;
  background-size: 720px auto !important;
}
html.panpal-dark .pp-main-recipe{background-image:none !important;}

/* Cards: softer, paper-like */
.pp-recipe-card,
.pp-recipe-stats{
  background: rgba(255,255,255,.78) !important;
  border: 1px solid rgba(17,24,39,.10) !important;
  box-shadow: 0 16px 44px rgba(17,24,39,.10) !important;
  border-radius: 18px !important;
  backdrop-filter: blur(10px) !important;
  -webkit-backdrop-filter: blur(10px) !important;
}
html.panpal-dark .pp-recipe-card,
html.panpal-dark .pp-recipe-stats{
  background: rgba(17,24,39,.55) !important;
  border-color: rgba(255,255,255,.14) !important;
  box-shadow: 0 18px 48px rgba(0,0,0,.45) !important;
}

/* Title + text */
.pp-recipe-title{
  font-family: 'Playfair Display', ui-serif, Georgia, 'Times New Roman', Times, serif !important;
  letter-spacing: -0.02em !important;
}
.pp-recipe-desc{
  font-size: 16px !important;
  line-height: 1.6 !important;
}

/* Hero image like reference */
.pp-recipe-hero{border-radius: 22px !important;}
.pp-recipe-hero-img{max-height: 440px !important; object-fit: cover !important;}

/* Ingredients photo inside card */
.pp-recipe-ingredients-photo,
.pp-recipe-ingredients-photo img{
  display:block;
  width:100%;
  border-radius: 16px !important;
}
.pp-recipe-ingredients-photo{
  overflow:hidden;
  border: 1px solid rgba(17,24,39,.10);
  box-shadow: 0 12px 32px rgba(17,24,39,.12);
  margin: 4px 0 14px;
}
html.panpal-dark .pp-recipe-ingredients-photo{border-color:rgba(255,255,255,.14); box-shadow:0 14px 34px rgba(0,0,0,.45)}

/* Ingredients list typography */
.pp-ingredients,
.pp-ingredients-list{
  font-size: 15px !important;
  line-height: 1.65 !important;
}
.pp-ingredients-list{list-style:none !important; padding:0 !important; margin:0 !important;}
.pp-ingredients-list li{
  padding: 8px 0 !important;
  border-bottom: 1px dashed rgba(17,24,39,.14) !important;
}
html.panpal-dark .pp-ingredients-list li{border-bottom-color: rgba(255,255,255,.16) !important;}
.pp-ingredients-list li:last-child{border-bottom:0 !important;}

/* Instructions look tighter + clearer */
.pp-steps,
.pp-instructions{
  font-size: 15px !important;
  line-height: 1.65 !important;
}
.pp-steps li{margin: 10px 0 !important;}

/* Chips: softer pills */
.pp-chip{
  background: rgba(255,255,255,.72) !important;
  border: 1px solid rgba(17,24,39,.10) !important;
  box-shadow: 0 10px 22px rgba(17,24,39,.08) !important;
}
html.panpal-dark .pp-chip{
  background: rgba(17,24,39,.55) !important;
  border-color: rgba(255,255,255,.14) !important;
  box-shadow: 0 12px 28px rgba(0,0,0,.35) !important;
}

/* Stat icons: crisper */
.pp-stat-ico{
  background: rgba(17,24,39,.06) !important;
  border: 1px solid rgba(17,24,39,.10) !important;
}
html.panpal-dark .pp-stat-ico{
  background: rgba(255,255,255,.08) !important;
  border-color: rgba(255,255,255,.14) !important;
}


/* === Recipe page: tighten to reference mockup === */
.pp-recipe, .pp-recipe *{
  font-family: 'Inter', system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
}
.pp-recipe-title{
  font-family: 'Playfair Display', Georgia, 'Times New Roman', serif;
  letter-spacing: -0.01em;
}
.pp-section-title, .pp-card-title{
  font-family: 'Playfair Display', Georgia, 'Times New Roman', serif;
}
.pp-ingredients li, .pp-instructions li, .pp-card, .pp-chip, .pp-stat{
  font-feature-settings: 'tnum' 1, 'lnum' 1;
}

/* Soften paper texture (avoid harsh dots) */
body{
  background-color: var(--bg);
  background-image: none !important;
}
body::before{
  content:'';
  position:fixed;
  inset:0;
  background: url('../img/paper-bg.webp') repeat;
  opacity: .18;
  pointer-events:none;
  z-index:0;
}


/* Material Symbols tuning */
.material-symbols-rounded{
  font-variation-settings: 'FILL' 0, 'wght' 500, 'GRAD' 0, 'opsz' 24;
  line-height: 1;
  display: inline-block;
}
.pp-ico-wrap .material-symbols-rounded{font-size:20px;}
.pp-mchip-ico .material-symbols-rounded{font-size:18px; opacity:.92;}


/* Statbar: one long bar, 2 tiers (tags spans full width) */
.pp-statbar{
  display:grid;
  grid-template-columns:repeat(4, minmax(0, 1fr));
  gap:0;
  padding:6px;
  border-radius:22px;
  background:rgba(255,255,255,.62);
  border:1px solid rgba(17,24,39,.10);
  box-shadow:0 10px 32px rgba(17,24,39,.08);
}
html.panpal-dark .pp-statbar{
  background:rgba(17,24,39,.55);
  border-color:rgba(255,255,255,.10);
}

.pp-statbar-item{
  min-width:0;
  border:0;
  background:transparent;
  border-radius:16px;
  padding:12px 14px;
  position:relative;
}
.pp-statbar-item:after{
  content:'';
  position:absolute;
  top:10px; bottom:10px; right:0;
  width:1px;
  background:rgba(17,24,39,.10);
}
html.panpal-dark .pp-statbar-item:after{background:rgba(255,255,255,.10);}
.pp-statbar-item:nth-child(4):after{display:none;}

.pp-statbar-item:last-child{
  grid-column:1/-1;
  padding-top:14px;
  margin-top:2px;
}
.pp-statbar-item:last-child:before{
  content:'';
  position:absolute;
  left:10px; right:10px; top:0;
  height:1px;
  background:rgba(17,24,39,.10);
}
html.panpal-dark .pp-statbar-item:last-child:before{background:rgba(255,255,255,.10);}
.pp-statbar-item:last-child:after{display:none;}

@media (max-width: 960px){
  .pp-statbar{grid-template-columns:repeat(2, minmax(0, 1fr));}
  .pp-statbar-item:nth-child(2):after{display:none;}
  .pp-statbar-item:nth-child(4):after{display:none;}
}


/* Top block: statbar + description + share + meta chips in one rounded container */
.pp-topcard{
  border-radius:22px;
  border:1px solid rgba(17,24,39,.10);
  background:rgba(255,255,255,.62);
  box-shadow:0 10px 32px rgba(17,24,39,.08);
  padding:6px;
  margin:12px 0 12px;
}
html.panpal-dark .pp-topcard{
  background:rgba(17,24,39,.55);
  border-color:rgba(255,255,255,.10);
}

.pp-topcard .pp-statbar{
  border:0;
  box-shadow:none;
  background:transparent;
  padding:0;
}

.pp-topcard .pp-recipe-desc{
  margin:10px 8px 10px;
  max-width: 95ch;
}

.pp-topcard .pp-share{
  margin:0 8px 8px;
}

.pp-topcard .pp-meta-chips{
  margin:8px 6px 2px;
}


/* Share buttons: match Material rounded icon weight */
.pp-share-btn{
  width:34px;height:34px;border-radius:999px;
  display:inline-flex;align-items:center;justify-content:center;
  border:1px solid rgba(17,24,39,.10);
  background:rgba(255,255,255,.72);
}
html.panpal-dark .pp-share-btn{
  background:rgba(11,15,20,.30);
  border-color:rgba(255,255,255,.10);
}
.pp-share-btn .pp-ico{width:18px;height:18px;stroke-width:1.8;}


/* Unify statbar + meta into one continuous bar */
.pp-topcard{padding:0; overflow:hidden;}
.pp-topcard .pp-statbar{padding:6px;}
.pp-topcard .pp-recipe-desc{margin:10px 14px 10px;}
.pp-topcard .pp-share{margin:0 14px 10px;}

.pp-topcard .pp-meta-chips{
  margin:0;
  padding:6px;
  border-top:1px solid rgba(17,24,39,.10);
}
html.panpal-dark .pp-topcard .pp-meta-chips{border-top-color:rgba(255,255,255,.10);}

/* meta tier as segments (not pills) */
.pp-topcard .pp-meta-chips-in{
  display:grid;
  grid-template-columns:repeat(5, minmax(0, 1fr));
  gap:0;
}
@media (max-width: 960px){
  .pp-topcard .pp-meta-chips-in{grid-template-columns:repeat(2, minmax(0, 1fr));}
}

.pp-topcard .pp-mchip{
  background:transparent;
  border:0;
  border-radius:0;
  padding:12px 14px;
  min-width:0;
  justify-content:flex-start;
  position:relative;
}
.pp-topcard .pp-mchip:after{
  content:'';
  position:absolute;
  top:10px; bottom:10px; right:0;
  width:1px;
  background:rgba(17,24,39,.10);
}
html.panpal-dark .pp-topcard .pp-mchip:after{background:rgba(255,255,255,.10);}
.pp-topcard .pp-mchip:nth-child(5):after{display:none;}
@media (max-width: 960px){
  .pp-topcard .pp-mchip:nth-child(2):after{display:none;}
}

/* tighten label/value in segments */
.pp-topcard .pp-mchip-label{font-size:12px;}
.pp-topcard .pp-mchip-val{font-size:13px; font-weight:700; letter-spacing:-0.01em;}
.pp-topcard .pp-mchip-ico{width:30px;height:30px;border-radius:999px;background:rgba(17,24,39,.06);border:1px solid rgba(17,24,39,.10);display:inline-flex;align-items:center;justify-content:center;}
html.panpal-dark .pp-topcard .pp-mchip-ico{background:rgba(255,255,255,.08);border-color:rgba(255,255,255,.10);}
.pp-topcard .pp-mchip-ico .material-symbols-rounded{font-size:20px;}


/* Unified top bar grid (stats + tags + cuisine/main + desc + diet/allergens/difficulty) */
.pp-topcard{padding:0; overflow:hidden;}
.pp-topgrid{
  display:grid;
  grid-template-columns:repeat(12, minmax(0, 1fr));
  gap:0;
  padding:6px;
}
.pp-topseg{
  display:flex;
  align-items:center;
  gap:12px;
  padding:12px 14px;
  min-width:0;
  position:relative;
  background:transparent;
}
.pp-topseg .pp-stat-txt{min-width:0;}
.pp-topseg .pp-stat-label{font-size:12px; opacity:.75; line-height:1.2;}
.pp-topseg .pp-stat-val{font-size:14px; font-weight:700; letter-spacing:-0.01em; line-height:1.25; word-break:break-word;}
.pp-topseg .pp-ico-wrap{
  width:32px;height:32px;border-radius:999px;
  background:rgba(17,24,39,.06);
  border:1px solid rgba(17,24,39,.10);
  display:inline-flex;align-items:center;justify-content:center;
  flex:0 0 auto;
}
html.panpal-dark .pp-topseg .pp-ico-wrap{background:rgba(255,255,255,.08); border-color:rgba(255,255,255,.10);}
.pp-topseg .pp-ico-wrap .material-symbols-rounded{font-size:20px;}

.pp-topseg:after{
  content:'';
  position:absolute;
  top:10px; bottom:10px; right:0;
  width:1px;
  background:rgba(17,24,39,.10);
}
html.panpal-dark .pp-topseg:after{background:rgba(255,255,255,.10);}
.pp-topseg--end:after{display:none;}

.pp-topseg--stat{grid-column:span 3;}
.pp-topseg--full{grid-column:1/-1;}
.pp-topseg--half{grid-column:span 6;}
.pp-topseg--third{grid-column:span 4;}

/* horizontal separators for new rows */
.pp-topseg--tags,
.pp-topseg--cuisine,
.pp-topseg--main,
.pp-topdesc,
.pp-topseg--diet,
.pp-topseg--allergens,
.pp-topseg--difficulty{
  border-top:1px solid rgba(17,24,39,.10);
}
html.panpal-dark .pp-topseg--tags,
html.panpal-dark .pp-topseg--cuisine,
html.panpal-dark .pp-topseg--main,
html.panpal-dark .pp-topdesc,
html.panpal-dark .pp-topseg--diet,
html.panpal-dark .pp-topseg--allergens,
html.panpal-dark .pp-topseg--difficulty{
  border-top-color:rgba(255,255,255,.10);
}

.pp-topdesc{
  padding:12px 14px;
}
.pp-topdesc .pp-recipe-desc{
  margin:0 0 10px;
  max-width:95ch;
}
.pp-topdesc .pp-share{margin:0;}

/* Responsive: let blocks wrap */
@media (max-width: 1024px){
  .pp-topseg--stat{grid-column:span 6;}
  .pp-topseg--half{grid-column:1/-1;}
  .pp-topseg--third{grid-column:span 6;}
}
@media (max-width: 640px){
  .pp-topseg--stat, .pp-topseg--third{grid-column:1/-1;}
}


/* Prevent ugly mid-word breaks; only break very long tokens if needed */
.pp-topseg .pp-stat-val{
  word-break: normal;
  overflow-wrap: break-word;
  hyphens: auto;
}


/* Share: allow many buttons without stretching */
.pp-topdesc{
  border-top:1px solid rgba(17,24,39,.10);
  padding:12px 14px 14px;
}
html.panpal-dark .pp-topdesc{border-top-color:rgba(255,255,255,.10);}
.pp-topdesc .pp-recipe-desc{margin:0 0 10px; max-width: 95ch;}
.pp-share{display:flex; flex-wrap:wrap; gap:8px;}
.pp-share-btn{flex:0 0 auto;}
.pp-share-copy.pp-copied{transform:scale(0.96);}


/* Auto-fit cells in top bar (no fixed widths) */
.pp-topgrid{
  display:flex !important;
  flex-wrap:wrap;
  align-items:stretch;
  padding:6px;
  gap:0;
}

/* remove grid-column driven sizing */
.pp-topseg--stat,
.pp-topseg--full,
.pp-topseg--half,
.pp-topseg--third{
  grid-column:auto !important;
}

/* each cell sizes by content, wraps naturally */
.pp-topseg{
  flex: 0 1 auto;
  min-width: 190px;
  max-width: 100%;
  padding:12px 14px;
  border:0;
  box-shadow:
    inset -1px 0 0 rgba(17,24,39,.10),
    inset 0 -1px 0 rgba(17,24,39,.10);
}
html.panpal-dark .pp-topseg{
  box-shadow:
    inset -1px 0 0 rgba(255,255,255,.10),
    inset 0 -1px 0 rgba(255,255,255,.10);
}

/* do not add row separators based on old "row" classes */
.pp-topseg--tags,
.pp-topseg--cuisine,
.pp-topseg--main,
.pp-topseg--diet,
.pp-topseg--allergens,
.pp-topseg--difficulty{
  border-top:0 !important;
}

/* tags often longest: let it expand */
.pp-topseg--tags{flex: 1 1 340px;}

/* help long texts wrap without ugly mid-word breaks */
.pp-topseg .pp-stat-val{
  word-break: normal;
  overflow-wrap: anywhere; /* last resort for very long tokens */
  hyphens: auto;
}

/* remove the old right separator pseudo (grid mode) */
.pp-topseg:after{display:none !important;}

/* responsive: smaller minimums so it becomes 2 rows instead of empty space */
@media (max-width: 1100px){
  .pp-topseg{min-width: 170px;}
  .pp-topseg--tags{flex-basis: 360px;}
}
@media (max-width: 640px){
  .pp-topseg{min-width: 100%;}
}


/* Fixed 2 bars x 5 cells (requested) */
.pp-topcard{padding:0; overflow:hidden;}
.pp-topbars{padding:6px;}
.pp-topbar{
  display:grid;
  grid-template-columns: repeat(5, minmax(0, 1fr));
  gap:0;
  background:transparent;
}
.pp-topbar--a{border-bottom:1px solid rgba(17,24,39,.10);}
html.panpal-dark .pp-topbar--a{border-bottom-color:rgba(255,255,255,.10);}

.pp-topcell{
  display:flex;
  align-items:center;
  gap:12px;
  padding:12px 14px;
  min-width:0;
  position:relative;
  background:transparent;
}
.pp-topcell:after{
  content:'';
  position:absolute;
  top:10px; bottom:10px; right:0;
  width:1px;
  background:rgba(17,24,39,.10);
}
html.panpal-dark .pp-topcell:after{background:rgba(255,255,255,.10);}
.pp-topbar .pp-topcell:last-child:after{display:none;}

.pp-topcell .pp-ico-wrap{
  width:32px;height:32px;border-radius:999px;
  background:rgba(17,24,39,.06);
  border:1px solid rgba(17,24,39,.10);
  display:inline-flex;align-items:center;justify-content:center;
  flex:0 0 auto;
}
html.panpal-dark .pp-topcell .pp-ico-wrap{background:rgba(255,255,255,.08); border-color:rgba(255,255,255,.10);}
.pp-topcell .pp-ico-wrap .material-symbols-rounded{font-size:20px;}

.pp-topcell .pp-stat-txt{min-width:0;}
.pp-topcell .pp-stat-label{font-size:12px; opacity:.75; line-height:1.2;}
.pp-topcell .pp-stat-val{
  font-size:14px;
  font-weight:700;
  letter-spacing:-0.01em;
  line-height:1.25;
  white-space:normal;
  overflow-wrap:anywhere;
  word-break:normal;
  hyphens:auto;
}

/* responsive: keep readable */
@media (max-width: 1100px){
  .pp-topbar{grid-template-columns: repeat(3, minmax(0, 1fr));}
  .pp-topbar--a{border-bottom:0;}
  .pp-topbar + .pp-topbar{border-top:1px solid rgba(17,24,39,.10);}
  html.panpal-dark .pp-topbar + .pp-topbar{border-top-color:rgba(255,255,255,.10);}
  .pp-topbar .pp-topcell:nth-child(3n):after{display:none;}
}
@media (max-width: 680px){
  .pp-topbar{grid-template-columns: repeat(2, minmax(0, 1fr));}
  .pp-topbar .pp-topcell:nth-child(2n):after{display:none;}
}



/* Topbar cell links */
.pp-topcell-link{display:block;color:inherit;text-decoration:none;min-width:0;}
.pp-topcell-link:hover .pp-stat-label{opacity:1;}
.pp-topcell-link:hover .pp-stat-val{text-decoration:underline;text-decoration-thickness:1px;text-underline-offset:3px;}
