/*
Theme Name: Chäs Stöckli Diemtigen
Theme URI: https://chaesstoeckli.ch
Author: Sieber Engineering
Description: Landingpage-Theme für Chäs Stöckli Diemtigen – Tradition, die man schmeckt.
Version: 1.0.0
License: GNU General Public License v2 or later
Text Domain: chaesstoeckli
*/

:root{
  --cream:#F4F1EA;
  --panel:#ECE8DE;
  --ink:#1A1817;
  --muted:#4a4642;
  --accent:#E9BC4E;
  --accent-dark:#d9a93a;
  --line:#e1ddd2;
  --serif:"Playfair Display", Georgia, "Times New Roman", serif;
  --sans:"Inter", system-ui, -apple-system, "Segoe UI", Roboto, sans-serif;
}

*{box-sizing:border-box;}
html{scroll-behavior:smooth;}
body{
  margin:0;
  font-family:var(--sans);
  color:var(--ink);
  background:var(--cream);
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
}
a{color:inherit;text-decoration:none;}
img{max-width:100%;display:block;}
.container{max-width:1200px;margin:0 auto;padding:0 24px;}

/* ---------- Header ---------- */
.site-header{
  background:var(--cream);
  border-bottom:1px solid var(--line);
  position:sticky;top:0;z-index:50;
}
.header-inner{
  display:flex;align-items:center;justify-content:space-between;
  gap:24px;padding:14px 24px;max-width:1200px;margin:0 auto;
}
.brand{display:flex;flex-direction:column;align-items:flex-start;gap:2px;}
.brand img{height:50px;width:auto;}
.brand .brand-place{font-family:var(--serif);font-size:1.05rem;color:var(--muted);padding-left:60px;line-height:1;}
.brand .brand-text{display:flex;flex-direction:column;line-height:1.05;}
.brand .brand-name{font-family:var(--serif);font-size:1.55rem;font-weight:700;}
.brand .brand-sub{font-family:var(--serif);font-size:1.05rem;color:var(--muted);}
.main-nav ul{display:flex;gap:38px;list-style:none;margin:0;padding:0;}
.main-nav a{font-weight:500;font-size:1rem;transition:color .15s;}
.main-nav a:hover{color:var(--accent-dark);}
.nav-toggle{display:none;background:none;border:0;cursor:pointer;padding:8px;}
.nav-toggle span{display:block;width:28px;height:3px;background:var(--ink);margin:5px 0;border-radius:2px;}
.cs-cart-link{position:relative;display:none;align-items:center;color:var(--ink);}
.cs-cart-link.has-items{display:inline-flex;}
.cs-cart-link:hover{color:var(--accent-dark);}
.cs-cart-link .cs-cart-count{position:absolute;top:-7px;right:-9px;min-width:19px;height:19px;padding:0 4px;border-radius:10px;background:var(--accent);color:var(--ink);font-size:.72rem;font-weight:700;display:inline-flex;align-items:center;justify-content:center;}

/* ---------- Sonderzeiten-Banner ---------- */
.cs-special-banner{background:linear-gradient(180deg,#f8ecc6 0%,#f4e4b6 100%);border-bottom:1px solid #e6cf8f;}
.cs-sb-inner{display:flex;align-items:center;gap:22px;padding:13px 0;flex-wrap:wrap;}
.cs-sb-label{display:flex;align-items:center;gap:10px;font-family:var(--serif);font-size:1.05rem;white-space:nowrap;padding-right:22px;border-right:1px solid #e1c889;}
.cs-sb-ico{display:inline-flex;align-items:center;justify-content:center;width:32px;height:32px;border-radius:50%;background:var(--accent);color:#5e4708;flex:0 0 auto;}
.cs-sb-items{display:flex;align-items:stretch;gap:12px;list-style:none;margin:0;padding:0;flex-wrap:wrap;flex:1;}
.cs-sb-item{display:flex;align-items:center;gap:9px;background:rgba(255,255,255,.6);border:1px solid #ecd9a3;border-radius:10px;padding:7px 13px;line-height:1.25;}
.cs-sb-cal{color:var(--accent-dark);flex:0 0 auto;}
.cs-sb-text{display:flex;flex-direction:column;gap:2px;}
.cs-sb-line{display:flex;align-items:baseline;gap:7px;}
.cs-sb-date{font-weight:700;font-size:.95rem;}
.cs-sb-note{color:var(--muted);font-size:.82rem;}
.cs-sb-status{display:inline-block;width:max-content;font-size:.76rem;font-weight:600;padding:1px 9px;border-radius:999px;}
.cs-sb-status.is-closed{background:#f6dcd5;color:#a5341f;}
.cs-sb-status.is-open{background:#dcefd6;color:#2e6b27;}
.cs-sb-all{margin-left:auto;white-space:nowrap;font-weight:600;color:#5e4708;background:rgba(255,255,255,.55);border:1px solid #e1c889;border-radius:999px;padding:7px 16px;transition:background .15s;}
.cs-sb-all:hover{background:var(--accent);color:var(--ink);}
.cs-sb-all span{color:var(--accent-dark);}
@media (max-width:760px){
  .cs-sb-label{border-right:0;padding-right:0;}
  .cs-sb-all{margin-left:0;}
}

/* ---------- Hero ---------- */
.hero{display:grid;grid-template-columns:1fr 1fr;}
.hero-text{background:var(--panel);padding:90px 6% 90px 0;}
.hero-text-inner{max-width:560px;margin-left:auto;padding-left:24px;}
.hero h1{
  font-family:var(--serif);font-weight:700;
  font-size:clamp(2.6rem,5vw,3.7rem);line-height:1.08;margin:0 0 28px;
}
.hero p.lead{font-size:1.2rem;color:var(--muted);margin:0 0 40px;max-width:430px;}
.hero-media{
  background-size:cover;background-position:center;
  min-height:600px;
}
.btn{
  display:inline-block;font-family:var(--sans);font-weight:600;font-size:1.05rem;
  padding:16px 30px;border-radius:8px;cursor:pointer;transition:all .15s;border:2px solid transparent;
}
.btn-primary{background:var(--accent);color:var(--ink);}
.btn-primary:hover{background:var(--accent-dark);}
.btn-outline{background:transparent;border-color:var(--accent);color:var(--ink);margin-top:16px;}
.btn-outline:hover{background:var(--accent);}
.hero .btn{display:block;width:max-content;}

/* ---------- Features ---------- */
.features{padding:70px 0 60px;}
.features-grid{
  display:grid;grid-template-columns:repeat(4,1fr);gap:24px;text-align:center;
}
.feature{padding:10px 14px;border-right:1px solid var(--line);}
.feature:last-child{border-right:0;}
.feature .icon{height:80px;display:flex;align-items:center;justify-content:center;margin-bottom:20px;}
.feature .icon img{height:80px;width:auto;object-fit:contain;}
.feature h3{font-weight:700;font-size:1.15rem;margin:0;line-height:1.35;}

/* ---------- Promise ---------- */
.promise{border-top:1px solid var(--line);padding:64px 0 72px;}
.promise-inner{display:flex;align-items:center;justify-content:center;gap:48px;flex-wrap:wrap;text-align:center;}
.promise-text{max-width:460px;}
.promise h2{font-family:var(--serif);font-weight:700;font-size:2.2rem;margin:0 0 18px;}
.promise p{font-size:1.25rem;color:var(--muted);margin:0;}
.promise img{width:230px;height:auto;mix-blend-mode:multiply;}

/* ---------- Infobar ---------- */
.infobar{background:var(--panel);border-top:1px solid var(--line);padding:34px 0;}
.infobar-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:30px;}
.info-head{display:flex;align-items:center;gap:12px;margin-bottom:12px;}
.info-head svg{width:26px;height:26px;flex:0 0 auto;}
.info-head .info-icon-img{width:30px;height:30px;flex:0 0 auto;object-fit:contain;}
.info-head h4{margin:0;font-family:var(--serif);font-weight:700;font-size:1.15rem;}
.info-col p{margin:0;color:var(--muted);font-size:.98rem;line-height:1.6;}
.info-col a{color:var(--muted);}
.info-col a:hover{color:var(--accent-dark);}
.info-col .oh{display:flex;gap:16px;align-items:baseline;margin-bottom:3px;}
.info-col .oh>span:first-child{min-width:56px;white-space:nowrap;font-weight:600;color:var(--ink);}
.info-col .oh>span:last-child{color:var(--muted);}
@media (max-width:900px){
  .infobar-grid{grid-template-columns:repeat(2,1fr);gap:30px 24px;}
}
@media (max-width:520px){
  .infobar-grid{grid-template-columns:1fr;}
}

/* ---------- Footer ---------- */
.site-footer{border-top:1px solid var(--line);padding:30px 0;}
.footer-inner{display:flex;flex-direction:column;align-items:center;gap:10px;text-align:center;}
.footer-links{display:flex;align-items:center;gap:14px;font-size:.98rem;font-weight:500;}
.footer-links .sep{color:var(--line);}
.footer-links a{color:var(--ink);}
.footer-links a:hover{color:var(--accent-dark);}
.footer-credit{margin:0;font-size:.85rem;color:var(--muted);line-height:1.5;max-width:760px;}
.footer-credit-sub{white-space:nowrap;}
@media (max-width:600px){.footer-credit-sub{display:block;white-space:normal;}}

/* ---------- WooCommerce: Markenfarben (kein Blau/Lila) ---------- */
.woocommerce a{color:var(--accent-dark);}
.woocommerce a:hover{color:var(--ink);}
.woocommerce #respond input#submit,
.woocommerce a.button,
.woocommerce button.button,
.woocommerce input.button,
.woocommerce #payment #place_order,
.woocommerce-page button.button,
.woocommerce .button.alt,
.woocommerce input.button.alt{
	background:var(--accent);color:var(--ink);border:0;font-weight:600;border-radius:8px;
	text-shadow:none;box-shadow:none;
}
.woocommerce #respond input#submit:hover,
.woocommerce a.button:hover,
.woocommerce button.button:hover,
.woocommerce input.button:hover,
.woocommerce #payment #place_order:hover,
.woocommerce .button.alt:hover,
.woocommerce input.button.alt:hover{background:var(--accent-dark);color:var(--ink);}
.woocommerce .woocommerce-info,
.woocommerce .woocommerce-message,
.woocommerce .woocommerce-noreviews,
.woocommerce p.no-comments{border-top-color:var(--accent);background:#faf7ef;}
.woocommerce .woocommerce-info::before,
.woocommerce .woocommerce-message::before{color:var(--accent-dark);}
.woocommerce .woocommerce-error{border-top-color:#c0392b;}
.woocommerce #payment,
.woocommerce-checkout #payment{background:#f4f1ea;border-radius:10px;}
/* Zahlungsbereich minimal: nur eine Methode – Radio/Bubble ausblenden, kompakt */
.woocommerce-checkout #payment ul.payment_methods{padding:10px 14px 0;border:0;}
.woocommerce-checkout #payment ul.payment_methods li{margin:0;}
.woocommerce-checkout #payment ul.payment_methods li input[type=radio]{display:none;}
.woocommerce-checkout #payment ul.payment_methods li label{font-weight:600;margin:0;}
.woocommerce #payment div.payment_box{display:none !important;}
.woocommerce-checkout #payment div.form-row.place-order{padding:14px;}
.woocommerce form .form-row .required{color:var(--accent-dark);}
.woocommerce-checkout #payment ul.payment_methods li input[type=radio]:checked+label{color:var(--ink);}
.select2-container--default .select2-results__option--highlighted[aria-selected],
.select2-container--default .select2-selection--single .select2-selection__rendered{color:var(--ink);}
.select2-container--default .select2-results__option--highlighted[aria-selected]{background:var(--accent);color:var(--ink);}
.woocommerce-store-notice,p.demo_store{background:var(--accent);color:var(--ink);}

/* ---------- Warenkorb-Icon (Header) ---------- */
.cs-cart-link .cs-cart-ico{display:block;width:34px;height:auto;}
.cs-cart-link .cs-cart-count{top:-6px;right:-8px;}

/* ---------- Info-Bar: Haus-Icon ---------- */
.info-icon-img{height:42px;width:auto;object-fit:contain;}
.info-icon-img.cs-icon-haus{height:50px;}

/* ---------- Checkout: hübscher ---------- */
.woocommerce-checkout .col2-set,.woocommerce-checkout .col-1,.woocommerce-checkout .col-2{width:100%;float:none;}
.woocommerce-checkout form.checkout{display:grid;grid-template-columns:1fr 1fr;gap:28px;align-items:start;}
.woocommerce-checkout #customer_details{grid-column:1;}
.woocommerce-checkout #order_review,.woocommerce-checkout #order_review_heading{grid-column:2;}
.woocommerce-checkout #customer_details .woocommerce-billing-fields>h3,
.woocommerce-checkout #order_review_heading{font-family:'Playfair Display',Georgia,serif;font-size:1.5rem;margin:0 0 14px;}
.woocommerce-checkout .woocommerce-billing-fields__field-wrapper{background:#faf7ef;border:1px solid var(--line);border-radius:14px;padding:22px 22px 8px;}
.woocommerce form .form-row label{font-weight:600;font-size:.9rem;margin-bottom:4px;}
.woocommerce form .form-row input.input-text,
.woocommerce form .form-row select,
.woocommerce-checkout #order_review .input-text{border:1px solid var(--line);border-radius:10px;padding:12px 14px;background:#fff;box-shadow:none;}
.woocommerce form .form-row input.input-text:focus,
.woocommerce form .form-row select:focus{border-color:var(--accent);outline:none;box-shadow:0 0 0 3px rgba(214,178,84,.25);}
.woocommerce-checkout #order_review{background:#faf7ef;border:1px solid var(--line);border-radius:14px;padding:8px 22px 22px;}
.woocommerce-checkout table.shop_table{border:0;border-radius:0;background:transparent;}
.woocommerce-checkout table.shop_table th{border:0;}
.woocommerce-checkout table.shop_table td{border:0;border-top:1px solid var(--line);}
/* Zwischensumme-Zeile entfernen (überall) */
.cart-subtotal{display:none !important;}
/* 100-g-Preis je Position */
.cs-line-100g{display:block;font-size:.8rem;font-weight:500;color:#8a7d5f;margin-top:2px;}
/* Gewichtshinweis-Checkbox */
.cs-weight-ack{margin:6px 0 14px;font-size:.88rem;line-height:1.4;}
.cs-weight-ack label{font-weight:500;}
.woocommerce-terms-and-conditions-wrapper .woocommerce-privacy-policy-text{display:none;}
.woocommerce form.checkout #payment .terms,.cs-weight-ack{clear:both;}
.woocommerce #payment #place_order,.woocommerce-checkout button#place_order{width:100%;padding:15px;font-size:1.05rem;border-radius:12px;}
@media (max-width:780px){.woocommerce-checkout form.checkout{grid-template-columns:1fr;}.woocommerce-checkout #customer_details,.woocommerce-checkout #order_review,.woocommerce-checkout #order_review_heading{grid-column:1;}}

/* ---------- Responsive ---------- */
@media (max-width:900px){
  .hero{grid-template-columns:1fr;}
  .hero-text{padding:60px 24px;}
  .hero-text-inner{margin:0;padding:0;max-width:100%;}
  .hero-media{min-height:360px;order:-1;}
  .features-grid{grid-template-columns:repeat(2,1fr);gap:36px 12px;}
  .feature:nth-child(2){border-right:0;}
  .feature{border-bottom:1px solid var(--line);padding-bottom:28px;}
  .feature:nth-child(3),.feature:nth-child(4){border-bottom:0;}
  .main-nav{display:none;position:absolute;top:100%;left:0;right:0;background:var(--cream);border-bottom:1px solid var(--line);}
  .main-nav.open{display:block;}
  .main-nav ul{flex-direction:column;gap:0;padding:8px 24px 18px;}
  .main-nav li{padding:10px 0;border-bottom:1px solid var(--line);}
  .nav-toggle{display:block;}
}
@media (max-width:520px){
  .features-grid{grid-template-columns:1fr;}
  .feature{border-right:0;}
  .brand .brand-name{font-size:1.25rem;}
  .promise-inner{flex-direction:column;}
}
