/*
Theme Name: Chocolate & Friends Premium Theme
Author: OpenAI
Description: Premium WordPress-tema för Chocolate & Friends med autogenererade upplevelsesidor.
Version: 5.3.0
Text Domain: cfpremium
*/
:root{
  --bg:#fbf6f2;
  --bg-soft:#fffaf7;
  --text:#3c2418;
  --muted:#6d5246;
  --accent:#7b472d;
  --accent-2:#b7764d;
  --accent-3:#e9c7af;
  --line:#ecd9cc;
  --white:#ffffff;
  --shadow:0 20px 50px rgba(60,36,24,.10);
  --radius:28px;
  --container:1180px;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  background:linear-gradient(180deg,#fffaf7 0%,#fbf6f2 100%);
  color:var(--text);
  font-family:"Segoe UI",Arial,sans-serif;
  line-height:1.7;
}
img{max-width:100%;height:auto;display:block}
a{color:var(--accent);text-decoration:none}
a:hover{opacity:.94}
.container{width:min(var(--container),calc(100% - 32px));margin:0 auto}

.site-header{
  position:sticky;top:0;z-index:50;
  backdrop-filter:blur(12px);
  background:rgba(255,250,247,.88);
  border-bottom:1px solid rgba(123,71,45,.08);
}
.header-inner{display:flex;align-items:center;justify-content:space-between;gap:20px;min-height:78px}
.brand{font-family:Georgia,serif;font-size:1.55rem;font-weight:700;color:var(--text)}
.brand small{display:block;font-size:.72rem;letter-spacing:.15em;text-transform:uppercase;color:var(--muted);font-family:Arial,sans-serif}
.main-nav ul{display:flex;gap:20px;list-style:none;padding:0;margin:0;flex-wrap:wrap}
.main-nav a{font-weight:600;color:var(--text)}
.menu-toggle{display:none}

.hero,.page-shell{padding:52px 0}
.hero-card,.page-hero{
  background:
    radial-gradient(circle at top right, rgba(255,255,255,.16), transparent 30%),
    linear-gradient(135deg,#4e3020 0%,#6f432d 52%,#916043 100%);
  color:#fff7f1;
  border-radius:34px;
  padding:clamp(28px,4vw,58px);
  box-shadow:var(--shadow);
  position:relative;
  overflow:hidden;
}
.hero-card:before,.hero-card:after,.page-hero:before,.page-hero:after{
  content:"";position:absolute;border-radius:50%;background:rgba(255,255,255,.08)
}
.hero-card:before,.page-hero:before{width:290px;height:290px;right:-70px;top:-90px}
.hero-card:after,.page-hero:after{width:180px;height:180px;left:-40px;bottom:-60px}
.eyebrow{
  font-size:.75rem;letter-spacing:.16em;text-transform:uppercase;font-weight:700;opacity:.92;margin-bottom:10px
}
.hero h1,.page-hero h1{
  font-family:Georgia,serif;
  font-size:clamp(2.5rem,5vw,4.5rem);
  line-height:1.03;
  margin:0 0 16px;
  max-width:920px;
}
.hero p,.page-hero p{
  font-size:1.1rem;
  color:#f6e7dc;
  max-width:780px;
  margin:0 0 22px;
}
.hero-actions{display:flex;gap:14px;flex-wrap:wrap}

.btn{
  display:inline-block;padding:14px 22px;border-radius:999px;font-weight:700;
  transition:transform .18s ease, box-shadow .18s ease, opacity .18s ease;
}
.btn:hover{transform:translateY(-1px);box-shadow:0 12px 24px rgba(60,36,24,.12)}
.btn-primary{background:var(--accent);color:#fff}
.btn-secondary{background:#fff;color:var(--accent);border:1px solid var(--line)}
.btn-light{background:#fff4eb;color:#5d3725}

.section{padding:18px 0 28px}
.section-title,.page-section h2,.content-area h1,.content-area h2,.content-area h3,.card h3,.feature-box h2,.cta-box h2,.detail-card h3,.price-box h3{
  font-family:Georgia,serif;line-height:1.18;color:var(--text)
}
.section-title{font-size:2.2rem;margin:0 0 10px}
.lead{
  color:var(--muted);
  max-width:860px;
  margin:0 0 18px;
  font-size:1.06rem;
}

.cards{display:grid;grid-template-columns:repeat(5,minmax(0,1fr));gap:20px}
.card,.feature-box,.cta-box,.content-area article,.archive-card,.detail-card,.price-box{
  background:var(--white);
  border:1px solid var(--line);
  border-radius:var(--radius);
  box-shadow:var(--shadow);
}
.card,.detail-card,.price-box{padding:26px}
.card p,.detail-card p,.content-area .entry-content,.archive-card p{color:var(--muted)}
.card-link{display:inline-block;margin-top:8px;font-weight:700}

.feature-box{padding:28px;background:linear-gradient(180deg,#fffdfb,#fff7f1)}
.feature-list,.check-list{
  margin:0;padding-left:20px;color:var(--muted)
}
.feature-list li,.check-list li{margin:10px 0}

.quote{
  margin:16px 0 8px;
  background:linear-gradient(135deg,#5c3523,#774833);
  color:#fff1e7;
  border-radius:30px;
  padding:30px;
  box-shadow:var(--shadow);
  font-family:Georgia,serif;
  font-size:1.45rem;
}
.quote small{display:block;margin-top:12px;color:#efdbcd;font-size:.95rem;font-family:Arial,sans-serif}

.cta-box{
  padding:34px;
  background:linear-gradient(180deg,#fffdfb,#f8ebe1);
}
.site-footer{margin-top:40px;padding:24px 0 56px;color:var(--muted)}
.footer-box{
  background:#fff8f3;border:1px solid var(--line);border-radius:24px;padding:24px
}

.page-layout{display:grid;grid-template-columns:minmax(0,1.45fr) minmax(290px,.7fr);gap:24px;margin-top:24px}
.page-section{margin:0 0 24px}
.page-section h2{font-size:2rem;margin:0 0 10px}
.highlight-bar{display:flex;flex-wrap:wrap;gap:12px;margin:18px 0}
.highlight-pill{
  background:#fff7f1;border:1px solid var(--line);padding:10px 14px;border-radius:999px;color:var(--accent);font-weight:700
}
.price-box{background:linear-gradient(180deg,#fffdfb,#f8ece2)}
.price{font-size:2rem;font-family:Georgia,serif;color:var(--accent);margin:6px 0}
.note{color:var(--muted);font-size:.95rem}

.content-area{padding:40px 0}
.content-area article{padding:30px}
.entry-title{margin-top:0;font-size:clamp(2rem,4vw,3rem)}
.archive-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:20px}
.archive-card{padding:24px}
.archive-card h2{margin-top:0;font-size:1.5rem}

.notice-box{
  margin-top:20px;padding:18px;border-radius:20px;
  background:#fff7f1;border:1px solid var(--line);color:var(--muted)
}

@media (max-width:1200px){
  .cards{grid-template-columns:repeat(3,minmax(0,1fr))}
}
@media (max-width:1024px){
  .cards{grid-template-columns:repeat(2,minmax(0,1fr))}
}
@media (max-width:920px){
  .page-layout,.archive-grid{grid-template-columns:1fr}
}
@media (max-width:720px){
  .header-inner{align-items:flex-start;padding:14px 0}
  .menu-toggle{display:inline-block;background:var(--accent);color:#fff;border:0;border-radius:12px;padding:10px 14px;font-weight:700}
  .main-nav{display:none;width:100%}
  .main-nav.open{display:block}
  .main-nav ul{flex-direction:column;padding-top:10px}
  .cards{grid-template-columns:1fr}
  .hero-card,.page-hero{border-radius:26px}
}


.payment-flow{
  display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:18px;margin-top:18px
}
.payment-step{
  background:#fffdfb;border:1px solid var(--line);border-radius:24px;padding:22px;box-shadow:var(--shadow)
}
.payment-step .step-no{
  display:inline-block;background:var(--accent);color:#fff;border-radius:999px;padding:6px 10px;
  font-size:.8rem;font-weight:700;margin-bottom:12px
}
.payment-step h3{margin:0 0 8px;font-family:Georgia,serif}
.payment-step p{margin:0;color:var(--muted)}
.payment-note{
  margin-top:18px;padding:16px 18px;border-radius:20px;background:#fff7f1;border:1px solid var(--line);color:var(--muted)
}
@media (max-width:920px){
  .payment-flow{grid-template-columns:1fr}
}


.terms-box{
  background:linear-gradient(180deg,#fffdfb,#fff7f1);
  border:1px solid var(--line);
  border-radius:var(--radius);
  box-shadow:var(--shadow);
  padding:30px;
}
.terms-box h2{margin-top:0}
.terms-box h3{font-family:Georgia,serif;color:var(--text);margin:24px 0 8px}
.shop-box{
  background:var(--white);
  border:1px solid var(--line);
  border-radius:var(--radius);
  box-shadow:var(--shadow);
  padding:32px;
}
.shop-box p{color:var(--muted)}


.booking-shell{padding:18px 0 40px}
.booking-grid{display:grid;grid-template-columns:minmax(0,1.3fr) minmax(320px,.8fr);gap:24px;margin-top:24px}
.booking-panel,.booking-form-card,.booking-list-card{background:var(--white);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow);padding:26px}
.booking-toolbar{display:flex;align-items:center;justify-content:space-between;gap:14px;margin-bottom:18px}
.booking-month{font-family:Georgia,serif;font-size:1.7rem}
.booking-nav{display:flex;gap:10px}
.booking-nav button{border:1px solid var(--line);background:#fff7f1;color:var(--accent);border-radius:999px;padding:10px 14px;font-weight:700;cursor:pointer}
.booking-calendar{display:grid;grid-template-columns:repeat(7,minmax(0,1fr));gap:10px;min-height:420px}
.booking-weekday{text-align:center;font-size:.85rem;color:var(--muted);font-weight:700;text-transform:uppercase;letter-spacing:.08em;padding:8px 4px}
.booking-day{min-height:120px;border:1px solid var(--line);border-radius:18px;background:#fffdfb;padding:10px;display:flex;flex-direction:column;gap:8px}
.booking-day.is-other{opacity:.45}
.booking-day.is-selected{outline:2px solid var(--accent)}
.booking-day-head{display:flex;align-items:center;justify-content:space-between;gap:8px}
.booking-day-number{font-weight:700}
.booking-bookings{display:flex;flex-direction:column;gap:6px}
.booking-item{background:#fff1e6;color:var(--accent);border-radius:12px;padding:6px 8px;font-size:.8rem;line-height:1.35}
.booking-item small{display:block;color:var(--muted)}
.booking-day-btn{margin-top:auto;border:1px dashed var(--line);background:#fff;color:var(--accent);border-radius:12px;padding:8px 10px;font-weight:700;cursor:pointer}
.booking-form-card form{display:grid;gap:14px}
.booking-form-card label{display:grid;gap:6px;font-weight:600}
.booking-form-card input,.booking-form-card select,.booking-form-card textarea{width:100%;border:1px solid var(--line);border-radius:14px;padding:12px 14px;font:inherit;color:var(--text);background:#fffdfb}
.booking-time-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.booking-slot-help{margin-top:8px;color:var(--muted);font-size:.95rem}
.booking-checkbox{display:flex;align-items:center;gap:10px;font-weight:600}
.booking-checkbox input{width:auto}
.booking-status{margin:0 0 16px;padding:14px 16px;border-radius:16px;background:#fff7f1;border:1px solid var(--line)}
.booking-list-card ul{margin:0;padding-left:18px;color:var(--muted)}
@media (max-width:920px){.booking-grid{grid-template-columns:1fr}}
@media (max-width:640px){.booking-calendar{gap:6px}.booking-day{min-height:110px;padding:8px}}

.booking-day{background:#f1f1f1}
.booking-day-btn:disabled{opacity:.55;cursor:not-allowed;background:#e5e5e5;color:#777;border-style:solid}

.booking-panel{overflow-x:auto}

.booking-day.has-slot{
  background:#f7efe8;
  border-color:#cfa98f;
}
.booking-day.has-slot .booking-day-number{
  color:#7b472d;
}

.booking-day.is-past{
  background:#e3e3e3;
  border-color:#cfcfcf;
}
.booking-day.is-past .booking-day-number,
.booking-day.is-past .booking-item,
.booking-day.is-past .booking-item small{
  color:#8a8a8a;
}

.booking-form-card input,
.booking-form-card select,
.booking-form-card textarea,
.booking-form-card label,
.booking-day-btn,
.booking-nav button{
  cursor:text;
}
.booking-day-btn,
.booking-nav button{
  cursor:pointer;
}
.booking-form-card input:hover,
.booking-form-card select:hover,
.booking-form-card textarea:hover{
  cursor:text !important;
}
.booking-form-card input:focus,
.booking-form-card select:focus,
.booking-form-card textarea:focus{
  outline:2px solid #cfa98f;
  outline-offset:1px;
}

.booking-form-card *,
.booking-form-card *:hover{
  caret-color:auto;
}


.booking-upcoming-list{display:grid;gap:10px}
.booking-upcoming-item{
  background:#fff7f1;
  border:1px solid var(--line);
  border-radius:14px;
  padding:10px 12px;
  color:var(--text);
}
.booking-upcoming-item strong{display:block;color:var(--accent)}

.calendar-agenda{
  display:grid;
  gap:10px;
  margin:0 0 18px;
}
.calendar-agenda-item{
  background:#fff7f1;
  border:1px solid var(--line);
  border-radius:16px;
  padding:12px 14px;
}
.calendar-agenda-item strong{
  display:block;
  color:var(--accent);
}
.calendar-agenda-empty{
  color:var(--muted);
  padding:8px 0 14px;
}


.booking-day-btn{
  display:block;
  width:100%;
  min-height:24px;
  border:none;
  background:transparent;
  padding:0;
  margin-top:8px;
  font-size:0;
  box-shadow:none;
}
.booking-day-btn:disabled{
  background:transparent;
  opacity:1;
  border:none;
}
.booking-day.has-slot{
  background:#fff7f1;
  border-color:#cfa98f;
}
.booking-day.has-slot .booking-day-number{
  color:#7b472d;
  font-weight:700;
}
