:root {
  --ink: #203322;
  --forest: #2f4a32;
  --sage: #75836a;
  --gold: #a9854d;
  --cream: #f7f2e8;
  --paper: #fffdf8;
  --line: rgba(47, 74, 50, .16);
  --shadow: 0 24px 70px rgba(39, 54, 39, .11);
  --serif: Georgia, 'Times New Roman', serif;
  --sans: Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body { margin: 0; overflow-x: hidden; background: var(--paper); color: var(--ink); font-family: var(--sans); line-height: 1.65; }
body.menu-open { overflow: hidden; }
img { display: block; max-width: 100%; }
a { color: inherit; text-decoration: none; }
button, input, select, textarea { font: inherit; }
button { color: inherit; }
.container { width: min(1180px, calc(100% - 40px)); margin-inline: auto; }
.eyebrow { margin: 0 0 14px; color: var(--gold); font-size: .74rem; font-weight: 700; letter-spacing: .2em; text-transform: uppercase; }
h1, h2, h3 { font-family: var(--serif); font-weight: 400; line-height: 1.08; margin: 0; }
h1 { font-size: clamp(3rem, 7vw, 6.8rem); letter-spacing: -.045em; }
h2 { font-size: clamp(2.35rem, 4.5vw, 4.4rem); letter-spacing: -.035em; }
h3 { font-size: 1.5rem; }
p { margin: 0; }
.lead { color: #526153; font-size: clamp(1rem, 1.5vw, 1.2rem); max-width: 620px; }
.muted { color: #687369; }
.announcement { padding: 9px 20px; background: var(--forest); color: #f7f2e8; text-align: center; font-size: .73rem; letter-spacing: .11em; text-transform: uppercase; }
.site-header { position: sticky; z-index: 50; top: 0; background: rgba(255,253,248,.92); border-bottom: 1px solid var(--line); backdrop-filter: blur(18px); }
.nav { min-height: 96px; display: grid; grid-template-columns: 1fr auto 1fr; align-items: center; }
.nav-links, .nav-actions { min-width: 0; display: flex; align-items: center; gap: 20px; white-space: nowrap; }
.nav-links a, .nav-actions > a { font-size: .84rem; font-weight: 500; line-height: 1; letter-spacing: .01em; }
.nav-links a:hover, .nav-links a.active, .nav-actions > a:hover, .nav-actions > a.active { color: var(--gold); }
.brand { min-width: 0; display: flex; align-items: center; justify-content: center; font-size: 0; line-height: 0; letter-spacing: 0; white-space: nowrap; }
.brand-mark { width: 96px; height: 78px; flex: 0 0 auto; overflow: hidden; border: 0; border-radius: 0; background-image: url('a1.jpeg'); background-repeat: no-repeat; background-size: auto 78px; background-position: center center; color: transparent; font-size: 0; }
.nav-actions { justify-content: flex-end; }
.language-switcher { display: inline-flex; align-items: center; gap: 3px; padding: 3px; border: 1px solid var(--line); border-radius: 999px; background: rgba(255,255,255,.72); }
.language-switcher a { width: 28px; height: 27px; display: grid; place-items: center; border-radius: 50%; font-size: .88rem; line-height: 1; filter: saturate(.82); }
.language-switcher a:hover, .language-switcher a.active { background: var(--cream); filter: none; }
.icon-btn { width: 40px; height: 40px; display: grid; place-items: center; border: 0; background: transparent; cursor: pointer; }
.cart-link { position: relative; }
.cart-link svg { width: 22px; height: 22px; display: block; fill: none; stroke: currentColor; stroke-width: 1.7; stroke-linecap: round; stroke-linejoin: round; }
.cart-link:hover svg { stroke: var(--gold); }
.cart-count { position: absolute; right: -2px; top: 0; width: 17px; height: 17px; display: grid; place-items: center; border-radius: 50%; background: var(--gold); color: white; font-size: .65rem; }
.menu-btn { display: none; }
.mobile-panel { display: none; }
.hero { min-height: calc(100vh - 112px); display: grid; grid-template-columns: 1.05fr .95fr; }
.hero-copy { padding: 9vw max(40px, calc((100vw - 1180px)/2)); padding-right: 7vw; display: flex; flex-direction: column; justify-content: center; background: var(--cream); }
.hero-copy h1 em { color: var(--gold); font-weight: 400; }
.hero-copy .lead { margin-top: 28px; }
.hero-actions { display: flex; gap: 12px; margin-top: 34px; flex-wrap: wrap; }
.btn { min-height: 51px; display: inline-flex; align-items: center; justify-content: center; padding: 0 24px; border: 1px solid var(--forest); border-radius: 100px; background: var(--forest); color: white; font-size: .82rem; font-weight: 700; letter-spacing: .04em; cursor: pointer; transition: .25s ease; }
.btn:hover { transform: translateY(-2px); box-shadow: 0 10px 25px rgba(47,74,50,.18); }
.btn-outline { background: transparent; color: var(--forest); }
.btn-light { border-color: white; background: white; color: var(--forest); }
.hero-visual { position: relative; min-height: 620px; overflow: hidden; background: #ddd5c7; }
.hero-visual img { width: 100%; height: 100%; object-fit: cover; }
.hero-note { position: absolute; left: 30px; bottom: 30px; width: 180px; padding: 18px; border-radius: 4px; background: rgba(255,253,248,.88); backdrop-filter: blur(12px); font-family: var(--serif); font-size: 1.05rem; }
.trust-strip { border-block: 1px solid var(--line); }
.trust-grid { display: grid; grid-template-columns: repeat(4, 1fr); }
.trust-item { padding: 28px 22px; text-align: center; border-right: 1px solid var(--line); font-size: .78rem; letter-spacing: .04em; }
.trust-item:last-child { border: 0; }
.section { padding: 110px 0; }
.section-head { display: flex; justify-content: space-between; align-items: end; gap: 30px; margin-bottom: 50px; }
.text-link { padding-bottom: 5px; border-bottom: 1px solid var(--gold); color: var(--gold); font-size: .8rem; font-weight: 700; }
.category-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 18px; }
.category-card { min-height: 380px; position: relative; overflow: hidden; padding: 28px; display: flex; align-items: end; background: #e8e3d7; border-radius: 3px; }
.category-card::before { content: ''; position: absolute; z-index: 1; inset: 0; background: radial-gradient(circle at 70% 25%, rgba(255,255,255,.75), transparent 38%), linear-gradient(150deg, transparent 35%, rgba(47,74,50,.17)); }
.category-card:nth-child(2) { background: #dde2d6; }
.category-card:nth-child(3) { background: #eee3cf; }
.category-card:nth-child(4) { background: #d8ddd2; }
.category-art { position: absolute; z-index: 2; right: -10%; top: 5%; font-family: var(--serif); font-size: 14rem; color: rgba(47,74,50,.1); line-height: 1; }
.category-content { position: relative; z-index: 3; }
.category-content span { display: block; margin-top: 10px; color: #677167; font-size: .78rem; }
.category-card-slideshow::before { background: linear-gradient(to top, rgba(27,43,29,.82) 0%, rgba(27,43,29,.22) 48%, rgba(255,255,255,.05) 100%); }
.category-card-slideshow .category-content { color: #fff; }
.category-card-slideshow .category-content span { color: rgba(255,255,255,.82); }
.category-slideshow { position: absolute; z-index: 0; inset: 0; overflow: hidden; background: #f2f0eb; }
.category-slideshow img { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; opacity: 0; transform: scale(1.025); animation: category-crossfade 16s infinite ease-in-out; }
.category-slideshow img:nth-child(1) { animation-delay: 0s; }
.category-slideshow img:nth-child(2) { animation-delay: 4s; }
.category-slideshow img:nth-child(3) { animation-delay: 8s; }
.category-slideshow img:nth-child(4) { animation-delay: 12s; }
@keyframes category-crossfade {
  0% { opacity: 0; transform: scale(1.025); }
  6%, 25% { opacity: 1; transform: scale(1); }
  31%, 100% { opacity: 0; transform: scale(1.015); }
}
@media (prefers-reduced-motion: reduce) {
  .category-slideshow img { animation: none; opacity: 0; transform: none; }
  .category-slideshow img:first-child { opacity: 1; }
}
.product-grid { display: grid; grid-template-columns: repeat(4, minmax(0, 1fr)); gap: 22px; align-items: start; }
.product-card { min-width: 0; position: relative; }
.product-image { width: 100%; aspect-ratio: 4 / 5; overflow: hidden; background: #f0ede6; }
.product-image img { width: 100%; height: 100%; object-fit: cover; transition: transform .6s ease; }
.product-card:hover .product-image img { transform: scale(1.035); }
.product-tag { position: absolute; z-index: 2; top: 14px; left: 14px; padding: 6px 10px; background: rgba(255,253,248,.9); font-size: .66rem; letter-spacing: .08em; text-transform: uppercase; }
.product-info { min-height: 154px; padding: 18px 2px 0; display: flex; flex-direction: column; }
.product-info h3 { font-family: var(--sans); font-size: .96rem; font-weight: 600; }
.product-meta { margin-top: 7px; display: flex; justify-content: space-between; color: #6b756b; font-size: .78rem; }
.quick-add { width: 100%; min-height: 43px; margin-top: auto; background: transparent; border: 1px solid var(--line); cursor: pointer; transition: .2s; }
.quick-add:hover { background: var(--forest); color: white; }
.ritual { display: grid; grid-template-columns: 1fr 1fr; background: var(--forest); color: white; }
.ritual-image { min-height: 650px; }
.ritual-image img { width: 100%; height: 100%; object-fit: cover; }
.ritual-copy { padding: clamp(50px,8vw,110px); display: flex; flex-direction: column; justify-content: center; }
.ritual-copy .eyebrow { color: #d1b47e; }
.ritual-copy p:not(.eyebrow) { margin: 28px 0; color: #dce3da; }
.journal-grid { display: grid; grid-template-columns: 1.25fr 1fr 1fr; gap: 22px; }
.journal-card { border-top: 1px solid var(--line); padding-top: 18px; }
.journal-card:first-child { grid-row: span 2; }
.journal-card .number { color: var(--gold); font-family: var(--serif); font-size: 2.3rem; }
.journal-card h3 { margin: 26px 0 12px; }
.article-grid { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 24px; }
.article-card { min-height: 330px; padding: 34px; display: flex; flex-direction: column; border: 1px solid var(--line); background: var(--paper); transition: transform .25s ease, box-shadow .25s ease; }
.article-card:hover { transform: translateY(-4px); box-shadow: var(--shadow); }
.article-card .article-number { color: var(--gold); font-family: var(--serif); font-size: 2.2rem; }
.article-card h2 { margin: 34px 0 14px; font-size: 2rem; }
.article-card .text-link { align-self: flex-start; margin-top: auto; padding-top: 26px; }
.article-page { padding: 85px 0 110px; }
.article-shell { width: min(820px, calc(100% - 40px)); margin-inline: auto; }
.article-meta { margin: 20px 0 42px; display: flex; gap: 18px; flex-wrap: wrap; color: #758075; font-size: .78rem; }
.article-body { font-size: 1.02rem; }
.article-body h2 { margin: 52px 0 18px; font-size: clamp(1.8rem, 3vw, 2.45rem); }
.article-body h3 { margin: 32px 0 12px; font-family: var(--sans); font-size: 1.05rem; font-weight: 700; }
.article-body p, .article-body li { color: #4f5e51; }
.article-body p + p { margin-top: 18px; }
.article-body ul, .article-body ol { margin: 16px 0; padding-left: 24px; }
.article-body li { margin: 9px 0; }
.article-callout { margin: 36px 0; padding: 26px 28px; border-left: 3px solid var(--gold); background: var(--cream); }
.article-callout strong { display: block; margin-bottom: 7px; color: var(--ink); }
.source-box { margin-top: 58px; padding: 28px; border: 1px solid var(--line); background: #faf8f2; }
.source-box h2 { margin: 0 0 14px; font-family: var(--sans); font-size: .78rem; font-weight: 700; letter-spacing: .12em; text-transform: uppercase; }
.source-box a { display: block; margin: 8px 0; color: var(--gold); font-size: .82rem; text-decoration: underline; text-underline-offset: 3px; }
.legal-note { margin-top: 28px; color: #788178; font-size: .76rem; }
.newsletter { padding: 85px 0; background: var(--cream); text-align: center; }
.newsletter form { width: min(560px,100%); margin: 30px auto 0; display: flex; border-bottom: 1px solid var(--forest); }
.newsletter input { flex: 1; padding: 16px 5px; border: 0; outline: 0; background: transparent; }
.newsletter button { border: 0; background: transparent; font-weight: 700; cursor: pointer; }
.site-footer { padding: 72px 0 25px; background: #1f3021; color: #e8ede6; }
.footer-grid { display: grid; grid-template-columns: 1.4fr repeat(3,1fr); gap: 50px; }
.footer-brand { display: flex; flex-direction: column; align-items: center; text-align: center; }
.footer-brand .brand { width: 100%; justify-content: center; }
.footer-brand p { width: 100%; max-width: 330px; margin-top: 14px; color: #d1b47e; font-family: var(--serif); font-size: 1.1rem; letter-spacing: .08em; }
.footer-col h3 { margin-bottom: 18px; font-family: var(--sans); font-size: .78rem; font-weight: 700; letter-spacing: .1em; text-transform: uppercase; }
.footer-col a { display: block; margin: 9px 0; color: #bfc8be; font-size: .82rem; }
.footer-bottom { margin-top: 60px; padding-top: 20px; border-top: 1px solid rgba(255,255,255,.12); display: flex; justify-content: space-between; color: #9ba69b; font-size: .72rem; }
.page-hero { padding: 100px 0 70px; background: var(--cream); text-align: center; }
.page-hero h1 { font-size: clamp(3rem,6vw,5.8rem); }
.page-hero .lead { margin: 22px auto 0; }
.breadcrumbs { margin-bottom: 20px; color: #788078; font-size: .75rem; }
.shop-toolbar { padding: 26px 0; border-bottom: 1px solid var(--line); }
.toolbar-inner { display: flex; justify-content: space-between; gap: 18px 28px; align-items: center; flex-wrap: wrap; }
.filters { display: flex; gap: 8px; flex-wrap: wrap; }
.filter-btn { padding: 9px 16px; border: 1px solid var(--line); border-radius: 40px; background: white; font-size: .76rem; cursor: pointer; }
.filter-btn.active { background: var(--forest); color: white; }
.sort-select { margin-left: auto; border: 0; background: transparent; color: #667066; font-size: .78rem; }
.catalog-note { grid-column: 1/-1; padding: 34px; background: var(--cream); text-align: center; color: #657065; }
.product-detail { padding: 75px 0 110px; }
.detail-grid { display: grid; grid-template-columns: 1.08fr .92fr; gap: 75px; align-items: start; }
.gallery { display: grid; grid-template-columns: 90px 1fr; gap: 14px; }
.thumbs { display: flex; flex-direction: column; gap: 12px; }
.thumb { width: 100%; aspect-ratio: 1; overflow: hidden; padding: 0; border: 1px solid transparent; background: #f2eee6; cursor: pointer; }
.thumb.active { border-color: var(--gold); }
.thumb img { width: 100%; height: 100%; object-fit: cover; }
.main-image { height: 680px; background: #eee9df; }
.main-image img { width: 100%; height: 100%; object-fit: contain; }
.detail-copy { position: sticky; top: 125px; }
.detail-copy h1 { font-size: clamp(2.8rem,5vw,4.6rem); }
.rating { margin: 18px 0; color: var(--gold); font-size: .8rem; }
.price { margin: 24px 0; font-family: var(--serif); font-size: 1.8rem; }
.detail-actions { display: grid; grid-template-columns: 100px 1fr; gap: 10px; margin: 28px 0; }
.qty { display: flex; border: 1px solid var(--line); }
.qty button, .qty input { width: 33.33%; border: 0; text-align: center; background: transparent; }
.detail-points { margin: 28px 0; padding: 0; list-style: none; }
.detail-points li { padding: 13px 0; border-bottom: 1px solid var(--line); font-size: .86rem; }
.accordion { border-top: 1px solid var(--line); }
.accordion button { width: 100%; padding: 19px 0; display: flex; justify-content: space-between; border: 0; border-bottom: 1px solid var(--line); background: transparent; text-align: left; cursor: pointer; }
.accordion-content { display: none; padding: 18px 0; color: #637064; font-size: .88rem; }
.accordion-item.open .accordion-content { display: block; }
.content-grid { display: grid; grid-template-columns: .75fr 1.25fr; gap: 90px; }
.prose h2 { margin: 50px 0 18px; font-size: 2rem; }
.prose h2:first-child { margin-top: 0; }
.prose p, .prose li { color: #586458; }
.prose ul { padding-left: 20px; }
.values-grid { margin-top: 70px; display: grid; grid-template-columns: repeat(4,1fr); gap: 18px; }
.value-card { padding: 30px; border: 1px solid var(--line); }
.value-card span { color: var(--gold); font-family: var(--serif); font-size: 2rem; }
.value-card h3 { margin: 25px 0 10px; }
.contact-grid { display: grid; grid-template-columns: .85fr 1.15fr; gap: 80px; }
.contact-list { margin-top: 35px; }
.contact-item { padding: 20px 0; border-bottom: 1px solid var(--line); }
.contact-item small { display: block; color: #7a827a; }
.form-card { padding: 45px; background: var(--cream); }
.form-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 18px; }
.field { display: flex; flex-direction: column; gap: 7px; }
.field.full { grid-column: 1/-1; }
.field label { font-size: .75rem; font-weight: 700; }
.field input, .field textarea, .field select { width: 100%; padding: 13px 0; border: 0; border-bottom: 1px solid #aeb6aa; background: transparent; outline: 0; }
.field textarea { min-height: 110px; resize: vertical; }
.faq-wrap { width: min(850px, calc(100% - 40px)); margin-inline: auto; }
.faq-group { margin-bottom: 50px; }
.faq-group h2 { margin-bottom: 20px; font-size: 2rem; }
.faq-item { border-bottom: 1px solid var(--line); }
.faq-question { width: 100%; padding: 20px 0; display: flex; justify-content: space-between; border: 0; background: transparent; text-align: left; cursor: pointer; }
.faq-answer { display: none; padding: 0 30px 20px 0; color: #5f6b60; font-size: .9rem; }
.faq-item.open .faq-answer { display: block; }
.cart-layout { display: grid; grid-template-columns: 1.4fr .6fr; gap: 70px; align-items: start; }
.cart-item { padding: 20px 0; display: grid; grid-template-columns: 110px 1fr auto; gap: 22px; border-bottom: 1px solid var(--line); }
.cart-item img { width: 110px; height: 130px; object-fit: cover; }
.cart-item h3 { margin: 12px 0 8px; font-family: var(--sans); font-size: 1rem; font-weight: 600; }
.remove-btn { border: 0; background: none; color: #8a5a52; font-size: .75rem; cursor: pointer; }
.summary { position: sticky; top: 120px; padding: 35px; background: var(--cream); }
.summary h2 { font-size: 2rem; }
.summary-row { padding: 15px 0; display: flex; justify-content: space-between; border-bottom: 1px solid var(--line); font-size: .86rem; }
.summary-total { font-size: 1.1rem; font-weight: 700; }
.summary .btn { width: 100%; margin-top: 24px; }
.empty-cart { padding: 80px 20px; text-align: center; background: var(--cream); }
.legal-nav { position: sticky; top: 120px; }
.legal-nav a { display: block; padding: 10px 0; color: #667066; font-size: .85rem; }
.legal-nav a.active { color: var(--gold); }
.toast { position: fixed; z-index: 100; right: 25px; bottom: 25px; max-width: 360px; padding: 16px 20px; border-radius: 3px; background: var(--forest); color: white; box-shadow: var(--shadow); transform: translateY(120px); opacity: 0; transition: .3s; font-size: .84rem; }
.toast.show { transform: none; opacity: 1; }

@media (max-width: 1120px) {
  .nav { grid-template-columns: 1fr auto; }
  .nav-links { display: none; }
  .brand { justify-self: start; }
  .nav-actions .icon-btn:not(.cart-link), .nav-actions > a:not(.cart-link) { display: none; }
  .nav-actions .language-switcher { display: inline-flex; }
  .menu-btn { display: grid; }
  .mobile-panel { position: fixed; z-index: 49; inset: 135px 0 0; padding: 35px 20px; background: var(--paper); flex-direction: column; gap: 20px; }
  .menu-open .mobile-panel { display: flex; }
  .mobile-panel a { font-family: var(--serif); font-size: 1.8rem; }
  .hero { grid-template-columns: 1fr; }
  .hero-copy { padding: 90px 30px; }
  .hero-visual { min-height: 70vh; }
  .category-grid, .product-grid { grid-template-columns: repeat(2,1fr); }
  .ritual, .detail-grid, .contact-grid, .cart-layout, .content-grid { grid-template-columns: 1fr; }
  .detail-copy, .summary, .legal-nav { position: static; }
  .journal-grid { grid-template-columns: 1fr 1fr; }
  .article-grid { grid-template-columns: 1fr 1fr; }
  .footer-grid { grid-template-columns: 1fr 1fr; }
  .values-grid { grid-template-columns: repeat(2,1fr); }
}

@media (max-width: 640px) {
  .container { width: min(100% - 28px, 1180px); }
  .announcement { font-size: .64rem; }
  .nav { min-height: 72px; }
  .mobile-panel { inset-block-start: 106px; }
  .brand-mark { width: 74px; height: 60px; background-size: auto 60px; }
  .language-switcher a { width: 25px; height: 25px; font-size: .78rem; }
  .hero-copy { padding: 70px 22px; }
  .hero-visual { min-height: 540px; }
  .trust-grid { grid-template-columns: 1fr 1fr; }
  .trust-item:nth-child(2) { border-right: 0; }
  .trust-item:nth-child(-n+2) { border-bottom: 1px solid var(--line); }
  .section { padding: 75px 0; }
  .section-head { display: block; }
  .section-head .text-link { display: inline-block; margin-top: 20px; }
  .category-grid, .product-grid, .journal-grid, .article-grid, .footer-grid, .values-grid, .form-grid { grid-template-columns: 1fr; }
  .category-card { min-height: 280px; }
  .product-image { aspect-ratio: 4 / 5; }
  .ritual-image { min-height: 480px; }
  .ritual-copy { padding: 55px 28px; }
  .footer-bottom, .toolbar-inner { align-items: flex-start; flex-direction: column; }
  .gallery { grid-template-columns: 1fr; }
  .thumbs { order: 2; flex-direction: row; }
  .thumb { width: 70px; }
  .main-image { height: 520px; }
  .detail-grid { gap: 40px; }
  .detail-actions { grid-template-columns: 1fr; }
  .form-card { padding: 28px 20px; }
  .cart-item { grid-template-columns: 85px 1fr; }
  .cart-item img { width: 85px; height: 105px; }
  .cart-item > strong { grid-column: 2; }
}

/* KVKK / Google Consent Mode */
.cookie-banner {
  position: fixed;
  z-index: 1000;
  right: 24px;
  bottom: 24px;
  left: 24px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 28px;
  max-width: 920px;
  margin: 0 auto;
  padding: 20px 22px;
  border: 1px solid rgba(35, 63, 43, .18);
  border-radius: 12px;
  background: rgba(255, 253, 247, .98);
  box-shadow: 0 18px 55px rgba(24, 40, 29, .18);
  color: var(--ink);
}
.cookie-banner strong { display: block; margin-bottom: 5px; font-family: var(--serif); font-size: 1.08rem; }
.cookie-banner p { margin: 0; max-width: 620px; color: #687369; font-size: .78rem; line-height: 1.55; }
.cookie-banner a { color: inherit; text-decoration: underline; }
.cookie-actions { display: flex; flex: 0 0 auto; gap: 10px; }
.cookie-actions .btn { min-width: 105px; padding: 12px 16px; }

@media (max-width: 640px) {
  .cookie-banner { right: 12px; bottom: 12px; left: 12px; align-items: stretch; flex-direction: column; gap: 15px; padding: 18px; }
  .cookie-actions { display: grid; grid-template-columns: 1fr 1fr; }
  .cookie-actions .btn { width: 100%; min-width: 0; }
}
