/* Site variables - Modern Color Palette */
:root{
  --bg-primary:#f5ebe0;
  --bg-secondary:#e3d5ca;
  --bg-dark:#d5bdaf;
  --accent-burgundy:#8b2635;
  --accent-burgundy-light:#a83448;
  --accent-burgundy-dark:#6b1e28;
  --coffee:#4a3428;
  --coffee-light:#6b4e3d;
  --cream:#fdfaf5;
  --text-primary:#2d2424;
  --text-secondary:#5c4f4f;
  --text-muted:#8a7f7f;
  --glass:rgba(255,255,255,0.15);
  --glass-dark:rgba(0,0,0,0.08);
  --shadow-sm:0 2px 8px rgba(75,52,40,0.08);
  --shadow-md:0 8px 24px rgba(75,52,40,0.12);
  --shadow-lg:0 16px 48px rgba(75,52,40,0.18);
  --shadow-xl:0 24px 64px rgba(75,52,40,0.24);
  --max-width:1200px;
  --transition:all 0.4s cubic-bezier(0.4, 0, 0.2, 1);
}
*{
  box-sizing:border-box;
  margin:0;
  padding:0;
}
html{
  scroll-behavior:smooth;
  overflow-x:hidden;
}
body{
  font-family:'Inter','Segoe UI','Roboto',system-ui,sans-serif;
  background:linear-gradient(135deg, var(--bg-primary) 0%, var(--bg-secondary) 50%, var(--bg-dark) 100%);
  background-attachment:fixed;
  color:var(--text-primary);
  line-height:1.6;
  overflow-x:hidden;
  scrollbar-width:thin;
  scrollbar-color:var(--accent-burgundy) var(--bg-secondary);
}
.container{
  max-width:var(--max-width);
  margin:0 auto;
  padding:48px 24px;
}
/* Header / Hero */
.site-header{
  position:relative;
  overflow:hidden;
}
.nav{
  display:flex;
  justify-content:space-between;
  align-items:center;
  padding:24px 48px;
  position:fixed;
  top:0;
  left:0;
  right:0;
  z-index:1000;
  background:rgba(245,235,224,0.92);
  backdrop-filter:blur(20px);
  -webkit-backdrop-filter:blur(20px);
  border-bottom:1px solid rgba(139,38,53,0.12);
  box-shadow:var(--shadow-sm);
  transition:var(--transition);
}
.nav.scrolled{
  padding:16px 48px;
  background:rgba(245,235,224,0.98);
  box-shadow:var(--shadow-md);
}
.brand{
  height:56px;
  width:auto;
  transition:var(--transition);
  filter:drop-shadow(2px 2px 4px rgba(0,0,0,0.1));
}
.nav.scrolled .brand{
  height:48px;
}
.nav-actions{
  display:flex;
  gap:12px;
  align-items:center;
}

.nav-toggle{
  display:none;
  width:44px;
  height:44px;
  border-radius:12px;
  border:1px solid rgba(139,38,53,0.2);
  background:rgba(253,250,245,0.95);
  color:var(--coffee);
  font-size:24px;
  line-height:1;
  align-items:center;
  justify-content:center;
  cursor:pointer;
}
.hero{
  background-image:var(--hero-bg, url('images/back.png'));
  background-size:cover;
  background-position:center;
  background-attachment:scroll;
  background-repeat:no-repeat;
  min-height:100vh;
  display:flex;
  align-items:center;
  justify-content:center;
  position:relative;
  overflow:hidden;
  padding-top:80px;
}
.hero-bg-overlay{
  position:absolute;
  inset:0;
  background-size:cover;
  background-position:center;
  background-repeat:no-repeat;
  background-attachment:scroll;
  opacity:0;
  z-index:0;
  pointer-events:none;
  will-change:opacity;
}
.hero::before{
  content:'';
  position:absolute;
  inset:0;
  background:linear-gradient(135deg, rgba(139,38,53,0.75) 0%, rgba(74,52,40,0.65) 50%, rgba(0,0,0,0.5) 100%);
  z-index:1;
  animation:heroOverlay 3s ease-in-out;
}
@keyframes heroOverlay{
  from{opacity:0;}
  to{opacity:1;}
}
.hero-inner{
  position:relative;
  z-index:2;
  padding:64px;
  text-align:left;
  max-width:900px;
  animation:fadeInUp 1s ease-out 0.3s backwards;
  margin-right:auto;
}
@keyframes fadeInUp{
  from{
    opacity:0;
    transform:translateY(30px);
  }
  to{
    opacity:1;
    transform:translateY(0);
  }
}
.hero-title{
  font-size:clamp(36px, 6vw, 72px);
  font-weight:800;
  margin:0 0 24px;
  color:var(--cream);
  line-height:1.1;
  text-shadow:2px 4px 12px rgba(0,0,0,0.4);
  letter-spacing:-0.02em;
}
.hero-sub{
  color:rgba(253,250,245,0.95);
  margin:0 0 40px;
  font-size:clamp(18px, 2.5vw, 24px);
  font-weight:300;
  text-shadow:1px 2px 8px rgba(0,0,0,0.3);
  letter-spacing:0.01em;
}
.hero-ctas{
  display:flex;
  gap:20px;
  justify-content:flex-start;
  flex-wrap:wrap;
  animation:fadeInUp 1s ease-out 0.6s backwards;
}
/* Buttons - Modern Design */
.btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  background:var(--accent-burgundy);
  color:var(--cream);
  border:none;
  padding:14px 32px;
  border-radius:50px;
  cursor:pointer;
  text-decoration:none;
  font-weight:600;
  font-size:16px;
  transition:var(--transition);
  box-shadow:var(--shadow-sm);
  position:relative;
  overflow:hidden;
  letter-spacing:0.02em;
  text-align:center;
}
.btn::before{
  content:'';
  position:absolute;
  inset:0;
  background:linear-gradient(135deg, rgba(255,255,255,0.2), transparent);
  opacity:0;
  transition:var(--transition);
}
.btn:hover{
  background:var(--accent-burgundy-light);
  transform:translateY(-2px);
  box-shadow:var(--shadow-md);
}
.btn:hover::before{
  opacity:1;
}
.btn:active{
  transform:translateY(0);
}
.btn.white{
  background:var(--cream);
  color:var(--accent-burgundy);
  border:2px solid var(--accent-burgundy);
}
.btn.white:hover{
  background:var(--accent-burgundy);
  color:var(--cream);
}
.btn.ghost{
  background:rgba(253,250,245,0.15);
  color:var(--cream);
  border:2px solid rgba(253,250,245,0.4);
  backdrop-filter:blur(10px);
  -webkit-backdrop-filter:blur(10px);
}
.btn.ghost:hover{
  background:rgba(253,250,245,0.25);
  border-color:rgba(253,250,245,0.8);
}
.btn-large{
  padding:18px 48px;
  font-size:18px;
  font-weight:700;
}
.btn.secondary{
  background:var(--coffee);
  color:var(--cream);
}
.btn.secondary:hover{
  background:var(--coffee-light);
}
/* About Section - Modern Glass Design */
.about{
  padding:120px 0;
  background:linear-gradient(180deg, var(--bg-primary) 0%, var(--cream) 100%);
  position:relative;
}
.about::before{
  content:'';
  position:absolute;
  inset:0;
  background-image:radial-gradient(circle at 20% 50%, rgba(139,38,53,0.03) 0%, transparent 50%),
                   radial-gradient(circle at 80% 80%, rgba(74,52,40,0.03) 0%, transparent 50%);
  pointer-events:none;
}
.about .container{
  position:relative;
  z-index:1;
}
.about h2{
  font-size:clamp(36px, 5vw, 56px);
  margin-bottom:60px;
  text-align:center;
  color:var(--coffee);
  font-weight:800;
  letter-spacing:-0.02em;
}
.about-content{
  display:flex;
  flex-direction:row;
  align-items:center;
  gap:16px;
  margin-bottom:32px;
  opacity:0;
  animation:fadeInUp 0.8s ease-out forwards;
  animation-delay:0.2s;
}
.about-content:nth-child(3){
  animation-delay:0.4s;
}
.about-content.align-right{
  justify-content:flex-end;
  flex-direction:row-reverse;
  margin-right:-48px;
}
.about-content.justify-right{
  flex-direction:row-reverse;
  justify-content:flex-start;
  align-items:center;
  margin-right:0;
}
.about-image{
  width:140px;
  height:140px;
  border-radius:50%;
  object-fit:cover;
  border:4px solid var(--cream);
  box-shadow:var(--shadow-md);
  transition:var(--transition);
  flex-shrink:0;
}
.about-image:hover{
  transform:scale(1.05) rotate(3deg);
  box-shadow:var(--shadow-xl);
}
.speech-bubble{
  background:rgba(255,255,255,0.95);
  backdrop-filter:blur(20px);
  -webkit-backdrop-filter:blur(20px);
  padding:18px 22px;
  border-radius:18px;
  position:relative;
  color:var(--text-primary);
  max-width:520px;
  box-shadow:var(--shadow-md);
  border:1px solid rgba(139,38,53,0.1);
  transition:var(--transition);
}
.speech-bubble::after,
.speech-bubble.reverse::after{
  display:none;
  content:'';
}
.speech-bubble p{
  margin:0;
  line-height:1.6;
  font-size:16px;
  color:var(--text-secondary);
  font-weight:400;
}
/* Gallery - Modern Grid with Hover Effects */
.gallery{
  padding:120px 0;
  background:var(--cream);
  position:relative;
  overflow:hidden;
}
.gallery::before{
  content:'';
  position:absolute;
  top:0;
  left:0;
  right:0;
  height:1px;
  background:linear-gradient(90deg, transparent, var(--accent-burgundy), transparent);
  opacity:0.2;
}
.gallery h2{
  font-size:clamp(36px, 5vw, 56px);
  margin-bottom:16px;
  text-align:center;
  color:var(--coffee);
  font-weight:800;
  letter-spacing:-0.02em;
}
.gallery .muted{
  color:var(--text-muted);
  margin-bottom:48px;
  text-align:center;
  font-size:18px;
  font-weight:400;
}
.grid{
  display:grid;
  grid-template-columns:repeat(auto-fit, minmax(280px, 1fr));
  gap:24px;
  margin-top:48px;
  perspective:1000px;
}
.grid-item{
  width:100%;
  height:320px;
  object-fit:cover;
  border-radius:20px;
  cursor:pointer;
  transition:transform 0.5s cubic-bezier(0.4, 0, 0.2, 1), box-shadow 0.5s cubic-bezier(0.4, 0, 0.2, 1), opacity 0.6s ease-out;
  box-shadow:var(--shadow-sm);
  position:relative;
  overflow:hidden;
  will-change:transform;
}
.grid-item::before{
  content:'';
  position:absolute;
  inset:0;
  background:linear-gradient(135deg, rgba(139,38,53,0.35), rgba(74,52,40,0.35));
  opacity:0;
  transition:opacity 0.8s cubic-bezier(0.4, 0, 0.2, 1);
  z-index:1;
}
.grid-item::after{
  content:'🔍';
  position:absolute;
  top:50%;
  left:50%;
  transform:translate(-50%, -50%) scale(0);
  font-size:56px;
  z-index:2;
  opacity:0;
  transition:opacity 0.8s cubic-bezier(0.4, 0, 0.2, 1), transform 0.8s cubic-bezier(0.4, 0, 0.2, 1);
  filter:drop-shadow(0 6px 12px rgba(0,0,0,0.6));
}
.grid-item:hover{
  transform:translateY(-16px) scale(1.08);
  box-shadow:0 30px 70px rgba(75,52,40,0.35), var(--shadow-xl);
  z-index:10;
}
.grid-item:hover::before{
  opacity:1;
}
.grid-item:hover::after{
  opacity:1;
  transform:translate(-50%, -50%) scale(1);
}
@media (max-width: 768px){
  .grid{
    grid-template-columns:repeat(2, 1fr);
    gap:12px;
  }
  .grid-item{
    height:180px;
    border-radius:12px;
  }
  .gallery{
    padding:60px 0;
  }
  .gallery .container{
    padding:24px 16px;
  }
}
/* Footer - Modern Minimal */
.site-footer{
  padding:48px 0;
  background:linear-gradient(135deg, var(--coffee) 0%, var(--coffee-light) 100%);
  color:rgba(253,250,245,0.8);
  text-align:center;
  position:relative;
  overflow:hidden;
}
.site-footer::before{
  content:'';
  position:absolute;
  top:0;
  left:0;
  right:0;
  height:1px;
  background:linear-gradient(90deg, transparent, rgba(253,250,245,0.3), transparent);
}
.site-footer small{
  font-size:15px;
  font-weight:400;
  letter-spacing:0.05em;
}
/* Lightbox - Modern Overlay */
.lightbox{
  position:fixed;
  inset:0;
  background:rgba(29,24,24,0.96);
  backdrop-filter:blur(20px);
  -webkit-backdrop-filter:blur(20px);
  display:flex;
  align-items:center;
  justify-content:center;
  z-index:10000;
  opacity:0;
  transition:opacity 0.4s cubic-bezier(0.4, 0, 0.2, 1);
  pointer-events:none;
}
.lightbox:not(.hidden){
  opacity:1;
  pointer-events:all;
}
.lightbox.hidden{
  display:flex;
  opacity:0;
}
.lb-image{
  max-width:90vw;
  max-height:85vh;
  border-radius:16px;
  box-shadow:var(--shadow-xl);
  transform:scale(0.9);
  transition:transform 0.4s cubic-bezier(0.4, 0, 0.2, 1);
  cursor:pointer;
}
.lightbox:not(.hidden) .lb-image{
  transform:scale(1);
}
.lb-close{
  position:absolute;
  top:32px;
  right:32px;
  background:rgba(253,250,245,0.15);
  backdrop-filter:blur(10px);
  -webkit-backdrop-filter:blur(10px);
  border:1px solid rgba(253,250,245,0.2);
  color:var(--cream);
  width:56px;
  height:56px;
  border-radius:50%;
  font-size:24px;
  cursor:pointer;
  transition:var(--transition);
  display:flex;
  align-items:center;
  justify-content:center;
}
.lb-close:hover{
  background:var(--accent-burgundy);
  border-color:var(--accent-burgundy);
  transform:rotate(90deg);
}
.lb-nav{
  position:absolute;
  top:50%;
  transform:translateY(-50%);
  background:rgba(253,250,245,0.15);
  backdrop-filter:blur(10px);
  -webkit-backdrop-filter:blur(10px);
  border:1px solid rgba(253,250,245,0.2);
  color:var(--cream);
  width:64px;
  height:64px;
  border-radius:50%;
  font-size:32px;
  cursor:pointer;
  transition:var(--transition);
  display:flex;
  align-items:center;
  justify-content:center;
  font-weight:400;
  line-height:1;
  margin:0;
  padding:0;
  border:none;
}
.lb-nav:hover{
  background:var(--accent-burgundy);
  border-color:var(--accent-burgundy);
  transform:translateY(-50%) scale(1.1);
}
.lb-prev{
  left:32px;
}
.lb-prev:hover{
  transform:translateY(-50%) scale(1.1);
}
.lb-next{
  right:32px;
}
.lb-next:hover{
  transform:translateY(-50%) scale(1.1);
}
.lb-next:hover{
  transform:translate(0, -50%) scale(1.1);
}
/* Tablet Design (769px - 1024px) */
@media (max-width:1024px) and (min-width:769px){
  .hero{
    min-height:80vh;
    padding-top:80px;
  }
  .hero-inner{
    text-align:center;
    margin-right:auto;
    margin-left:auto;
  }
  .hero-inner{
    padding:48px 40px;
    max-width:700px;
  }
  .hero-title{
    font-size:clamp(38px, 5vw, 52px);
  }
  .hero-sub{
    font-size:20px;
  }
  .nav{
    padding:20px 32px;
  }
  .about{
    padding:100px 0;
  }
  .about-content{
    gap:36px;
    margin-bottom:60px;
  }
  .about-image{
    width:200px;
    height:200px;
  }
  .speech-bubble{
    max-width:550px;
    padding:28px;
  }
  .gallery{
    padding:100px 0;
  }
  .grid{
    grid-template-columns:repeat(3, 1fr);
    gap:20px;
  }
  .grid-item{
    height:260px;
  }
  .container{
    padding:40px 32px;
  }
}
/* Mobile Design (max 768px) */
@media (max-width:768px){
  .hero{
    min-height:100svh;
    padding-top:96px;
    padding-bottom:56px;
  }
  .hero::before{
    background:linear-gradient(135deg, rgba(139,38,53,0.75) 0%, rgba(74,52,40,0.65) 50%, rgba(0,0,0,0.5) 100%);
  }
  .hero-inner{
    padding:32px 24px;
    text-align:center;
    margin:0 auto;
  }
  .hero-title{
    font-size:clamp(28px, 8vw, 42px);
    margin-bottom:16px;
  }
  .hero-sub{
    font-size:16px;
    margin-bottom:32px;
  }
  .hero-ctas{
    flex-direction:column;
    gap:12px;
    justify-content:center;
    align-items:center;
  }
  .hero-ctas .btn{
    width:100%;
    max-width:280px;
  }
  .nav{
    padding:16px 24px;
    flex-wrap:wrap;
  }
  .nav-toggle{
    display:inline-flex;
    margin-left:auto;
  }
  .nav-actions{
    display:none;
    width:100%;
    margin-top:12px;
    padding:12px;
    background:rgba(253,250,245,0.98);
    border:1px solid rgba(139,38,53,0.12);
    border-radius:16px;
    box-shadow:var(--shadow-sm);
    flex-direction:column;
    gap:10px;
  }
  .nav.open .nav-actions{
    display:flex;
  }
  .nav-actions .btn{
    width:100%;
  }
  .brand{
    height:42px;
  }
  .about{
    padding:80px 0;
  }
  .about-content.justify-right{
    display:none;
  }
  .about-content,
  .about-content.align-right,
  .about-content.justify-right,
  .about-content.reverse{
    flex-direction:column;
    text-align:center;
    margin-right:0 !important;
    margin-bottom:40px;
    gap:24px;
    align-items:center;
  }
  .about-content.justify-right{
    flex-direction:column;
  }
  .about-image{
    width:140px;
    height:140px;
    border-radius:50%;
    object-fit:cover;
    border:4px solid var(--cream);
    box-shadow:var(--shadow-md);
    transition:var(--transition);
    flex-shrink:0;
  }
  .about-image:hover{
    transform:scale(1.05) rotate(3deg);
    box-shadow:var(--shadow-xl);
  }
  .speech-bubble::after,
  .speech-bubble{
    background:rgba(255,255,255,0.95);
    backdrop-filter:blur(20px);
    -webkit-backdrop-filter:blur(20px);
    padding:18px 22px;
    border-radius:18px;
    position:relative;
    color:var(--text-primary);
    max-width:90%;
    width:100%;
    box-shadow:var(--shadow-md);
    border:1px solid rgba(139,38,53,0.1);
    transition:var(--transition);
  }
  .speech-bubble::after,
  .speech-bubble.reverse::after{
    display:none;
    content:'';
  }
  .gallery{
    padding:80px 0;
  }
  .lb-close{
    top:16px;
    right:16px;
    width:48px;
    height:48px;
    font-size:20px;
  }
  .lb-nav{
    width:48px;
    height:48px;
    font-size:24px;
  }
  .lb-prev{
    left:16px;
  }
  .lb-next{
    right:16px;
  }
}
/* Custom Scrollbar - Modern */
::-webkit-scrollbar {
  width:12px;
}
::-webkit-scrollbar-track {
  background:var(--bg-secondary);
}
::-webkit-scrollbar-thumb {
  background:linear-gradient(180deg, var(--accent-burgundy) 0%, var(--accent-burgundy-dark) 100%);
  border-radius:6px;
  border:2px solid var(--bg-secondary);
}
::-webkit-scrollbar-thumb:hover {
  background:linear-gradient(180deg, var(--accent-burgundy-light) 0%, var(--accent-burgundy) 100%);
}
/* Prices Page - Premium Cards */
.prices-page{
  background:linear-gradient(135deg, var(--bg-primary) 0%, var(--bg-secondary) 100%);
  min-height:100vh;
}
.prices-page .site-header{
  position:relative;
}
.prices-page .nav{
  position:relative;
  background:rgba(245,235,224,0.98);
}
.prices-page .pricing{
  padding:120px 0;
}
.prices-page .pricing h1{
  font-size:clamp(42px, 6vw, 72px);
  text-align:center;
  color:var(--coffee);
  margin-bottom:80px;
  font-weight:800;
  letter-spacing:-0.02em;
}
.pricing-grid{
  display:grid;
  grid-template-columns:repeat(auto-fit, minmax(360px, 1fr));
  gap:32px;
  margin-top:48px;
}
.card{
  position:relative;
  background:rgba(255,255,255,0.95);
  backdrop-filter:blur(20px);
  -webkit-backdrop-filter:blur(20px);
  padding:32px;
  border-radius:28px;
  box-shadow:var(--shadow-md);
  text-align:center;
  transition:var(--transition);
  display:flex;
  flex-direction:column;
  border:1px solid rgba(139,38,53,0.08);
  overflow:hidden;
}
.card::before{
  content:'';
  position:absolute;
  top:0;
  left:0;
  right:0;
  height:4px;
  background:linear-gradient(90deg, var(--accent-burgundy), var(--coffee));
  transform:scaleX(0);
  transform-origin:left;
  transition:transform 0.6s cubic-bezier(0.4, 0, 0.2, 1);
}
.card:hover::before{
  transform:scaleX(1);
}
.card:hover{
  transform:translateY(-12px);
  box-shadow:var(--shadow-xl);
  border-color:rgba(139,38,53,0.16);
}
.card-img{
  width:100%;
  height:280px;
  object-fit:cover;
  border-radius:20px;
  margin-bottom:24px;
  box-shadow:var(--shadow-sm);
  transition:var(--transition);
}
.card-img-eskuvoi{
  object-position:center 62%;
}
.card-img[style*="object-position: center 17%"]{
  object-position:center 3%;
}
.card:hover .card-img{
  transform:scale(1.05);
  box-shadow:var(--shadow-md);
}
.card h3{
  margin:0 0 16px;
  color:var(--coffee);
  font-size:28px;
  font-weight:700;
  letter-spacing:-0.01em;
}
.card > p{
  margin:12px 0;
  color:var(--text-secondary);
  line-height:1.7;
  font-size:16px;
}
.card .price{
  font-weight:800;
  color:var(--accent-burgundy);
  font-size:32px;
  margin:20px 0;
  letter-spacing:-0.01em;
}
.card-actions{
  margin-top:auto;
  padding-top:20px;
  display:flex;
  flex-direction:column;
  gap:12px;
}
.card .btn{
  width:100%;
}
.card-details{
  text-align:left;
  margin:20px 0;
  padding:20px;
  background:linear-gradient(135deg, rgba(245,235,224,0.6), rgba(227,213,202,0.6));
  border:1px solid rgba(139,38,53,0.1);
  border-radius:16px;
  color:var(--text-primary);
}
.card-details strong{
  display:block;
  margin-bottom:12px;
  color:var(--coffee);
  font-size:17px;
  font-weight:700;
}
.card-details ul{
  padding-left:24px;
  margin:0;
}
.card-details li{
  margin:8px 0;
  color:var(--text-secondary);
  line-height:1.6;
}
.card-details li::marker{
  color:var(--accent-burgundy);
}

.prices-page #details-extrak{
  max-width:820px;
  margin:40px auto 0;
  padding:28px 30px;
  background:rgba(255,255,255,0.96);
  border:2px solid rgba(139,38,53,0.22);
  border-radius:20px;
  box-shadow:var(--shadow-md);
}

.prices-page #details-extrak strong{
  font-size:22px;
  color:var(--accent-burgundy);
  margin-bottom:14px;
}

.prices-page #details-extrak li{
  color:var(--text-primary);
  font-size:17px;
  line-height:1.7;
}
/* Expanded Card Styles */
.card.expanded{
  grid-column:1 / -1;
  padding:48px;
  max-width:100%;
}
.card.expanded .card-img{
  height:400px;
  margin-bottom:32px;
}
.card.expanded .card-img-eskuvoi{
  object-position:center 20%;
}
/* Option Cards within Expanded Cards */
.option-grid{
  display:none;
  margin-top:32px;
  text-align:left;
}
.card.expanded .option-grid{
  display:grid;
  grid-template-columns:repeat(auto-fit, minmax(280px, 1fr));
  gap:24px;
}
.option-card{
  background:rgba(255,255,255,0.9);
  border:1px solid rgba(139,38,53,0.12);
  border-radius:20px;
  padding:24px;
  box-shadow:var(--shadow-sm);
  display:flex;
  flex-direction:column;
  transition:var(--transition);
}
.option-card:hover{
  transform:translateY(-4px);
  box-shadow:var(--shadow-md);
  border-color:rgba(139,38,53,0.24);
}
.option-card h4{
  margin:0 0 16px;
  color:var(--coffee);
  font-size:22px;
  font-weight:700;
  letter-spacing:-0.01em;
}
.option-card .option-details{
  background:linear-gradient(135deg, rgba(245,235,224,0.5), rgba(227,213,202,0.5));
  border:1px solid rgba(139,38,53,0.08);
  border-radius:14px;
  padding:16px;
  margin-bottom:16px;
  flex-grow:1;
}
.option-card .option-details ul{
  padding-left:20px;
  margin:0;
}
.option-card .option-details li{
  margin:6px 0;
  color:var(--text-secondary);
  line-height:1.6;
}
.option-card .option-details li::marker{
  color:var(--accent-burgundy);
}
.option-card .price{
  font-size:28px;
  font-weight:800;
  color:var(--accent-burgundy);
  margin:16px 0;
  text-align:center;
}
.option-card .btn{
  width:100%;
  margin-top:auto;
}
/* Responsive Pricing Grid */
@media (min-width: 900px){
  .pricing-grid{
    grid-template-columns:repeat(2, 1fr);
  }
}
@media (min-width: 1200px){
  .pricing-grid{
    grid-template-columns:repeat(3, 1fr);
  }
}
@media (max-width: 768px){
  .pricing-grid{
    grid-template-columns:1fr;
  }
  .card{
    padding:24px;
  }
  .card.expanded{
    padding:32px 24px;
  }
  .option-grid{
    grid-template-columns:1fr;
  }
  .prices-page .pricing{
    padding:80px 0;
  }
  .prices-page .pricing h1{
    margin-bottom:48px;
  }
}

/* Gallery Categories Page */
.gallery-page{
  background:linear-gradient(135deg, var(--bg-primary) 0%, var(--bg-secondary) 100%);
}

.gallery-hero{
  padding:130px 0 56px;
  position:relative;
  background-image:url('images/back.jpeg');
  background-size:cover;
  background-position:center;
  background-repeat:no-repeat;
}

.gallery-hero::before{
  content:'';
  position:absolute;
  inset:0;
  background:rgba(253,250,245,0.78);
}

.gallery-hero .container{
  position:relative;
  z-index:1;
}

.gallery-hero h1{
  font-size:clamp(42px, 6vw, 72px);
  text-align:center;
  color:var(--coffee);
  margin-bottom:16px;
  font-weight:800;
  letter-spacing:-0.02em;
}

.gallery-hero .muted{
  text-align:center;
  margin-bottom:28px;
}

.category-chips{
  display:flex;
  flex-wrap:wrap;
  gap:12px;
  overflow-x:visible;
  padding-bottom:8px;
  justify-content:center;
}

.category-chip{
  white-space:nowrap;
  flex:0 0 auto;
  background:rgba(253,250,245,0.95);
  color:var(--coffee);
  border:2px solid var(--coffee);
  box-shadow:none;
}

.category-chip:link,
.category-chip:visited,
.category-chip:active,
.category-chip:focus,
.category-chip:focus-visible{
  background:rgba(253,250,245,0.95);
  color:var(--coffee);
  border-color:var(--coffee);
  box-shadow:none;
  transform:none;
  outline:none;
}

.category-chip::before{
  display:none;
}

.category-chip:hover{
  background:rgba(253,250,245,0.95);
  color:var(--coffee);
  border-color:var(--coffee);
  transform:translateY(-4px);
  box-shadow:0 14px 28px rgba(74,52,40,0.26);
}

.gallery-category{
  padding:24px 0 70px;
}

.gallery-category h2{
  font-size:clamp(30px, 4vw, 48px);
  margin-bottom:24px;
  color:var(--coffee);
  font-weight:800;
  letter-spacing:-0.02em;
}

@media (max-width: 768px){
  .gallery-hero{
    padding:100px 0 40px;
  }

  .category-chips{
    gap:10px;
  }

  .gallery-category{
    padding:16px 0 48px;
  }

  .gallery-category h2{
    margin-bottom:16px;
  }
}
