/* ==========================================================================
   Mansard — Design System (modern/luxury botanical)
   Loaded AFTER Bootstrap 5.3 (CDN). Hand-authored, no build step.
   Rethemes Bootstrap via CSS custom properties + adds components and
   mobile-first base rules that tame the legacy markup.
   ========================================================================== */

:root {
    /* Palette — matched to reference mansard.com (champagne + warm neutrals) */
    --ms-ivory:      #FFFFFF;   /* page background */
    --ms-cream:      #FBF3EE;   /* warm cream — alternating sections */
    --ms-white:      #FFFFFF;
    --ms-charcoal:   #262626;   /* headings / strong text */
    --ms-charcoal-2: #3C3C3C;   /* body text */
    --ms-taupe:      #7E7E7E;   /* muted text */
    --ms-sage:       #BFA489;   /* PRIMARY accent = champagne/tan (brand) — fills/borders/decoration */
    --ms-sage-hover: #AD8B68;   /* darker champagne */
    --ms-sage-50:    #F7EFE8;   /* light champagne tint (hover bg) */
    --ms-sage-text:  #7A5C38;   /* readable warm brand tone for TEXT/links/icons (AA on white) */
    --ms-champagne:  #BFA489;
    --ms-gold:       #BFA489;
    --ms-teal:       #32A88B;   /* secondary accent (sparingly) */
    --ms-border:     #E5E5E5;
    --ms-border-2:   #D9D9D9;

    /* Bootstrap theme hooks (used by body, links, badges, text-bg-*) */
    --bs-body-bg: var(--ms-ivory);
    --bs-body-color: var(--ms-charcoal-2);
    --bs-body-font-family: 'Open Sans', system-ui, -apple-system, 'Segoe UI', sans-serif;
    --ms-heading-font: 'Lora', Georgia, 'Times New Roman', serif;
    --ms-ui-font: 'Poppins', 'Open Sans', sans-serif;
    --bs-body-font-size: 1rem;
    --bs-body-line-height: 1.55;
    --bs-primary: #BFA489;
    --bs-primary-rgb: 191, 164, 137;
    --bs-secondary: #BFA489;
    --bs-secondary-rgb: 191, 164, 137;
    --bs-link-color: #7A5C38;
    --bs-link-color-rgb: 122, 92, 56;
    --bs-link-hover-color: #5E4729;
    --bs-link-hover-color-rgb: 94, 71, 41;
    --bs-border-color: #E5E5E5;
    --bs-border-radius: 2px;
    --bs-border-radius-sm: 0px;
    --bs-border-radius-lg: 4px;

    /* Tokens — flat / editorial (reference has minimal depth) */
    --ms-shadow-xs: 0 1px 2px rgba(35,35,35,.04);
    --ms-shadow-sm: 0 1px 4px rgba(35,35,35,.05);
    --ms-shadow-md: 0 6px 18px rgba(35,35,35,.07);
    --ms-shadow-lg: 0 14px 36px rgba(35,35,35,.10);
    --ms-ease: cubic-bezier(.4,0,.2,1);
    --ms-dur: .24s;

    /* Spacing scale (8px base) */
    --ms-space-1: .5rem;
    --ms-space-2: .75rem;
    --ms-space-3: 1rem;
    --ms-space-4: 1.5rem;
    --ms-space-5: 2rem;
    --ms-space-6: 3rem;
    --ms-space-7: 4rem;
    --ms-space-8: 6rem;
}

/* ===== Base / global fixes (tame legacy, mobile-first) ===== */
*, *::before, *::after { box-sizing: border-box; }
html, body { overflow-x: hidden; max-width: 100%; }
body {
    font-family: var(--bs-body-font-family);
    background: var(--ms-ivory);
    color: var(--ms-charcoal-2);
    line-height: 1.55;
    -webkit-font-smoothing: antialiased;
}
img, svg, video { max-width: 100%; height: auto; }

/* Headings — Lora serif, normal case (reference style) */
h1,h2,h3,h4,h5,h6,.h1,.h2,.h3,.h4,.h5,.h6 {
    font-family: var(--ms-heading-font);
    color: var(--ms-charcoal);
    font-weight: 400;
    line-height: 1.35;
    letter-spacing: 0;
    text-transform: none;
}
h1,.h1 { font-size: clamp(1.9rem, 1.4rem + 1.6vw, 2.25rem); line-height: 1.3; }
h2,.h2 { font-size: clamp(1.6rem, 1.2rem + 1.2vw, 1.875rem); line-height: 1.4; }
h3,.h3 { font-size: clamp(1.3rem, 1.05rem + .8vw, 1.5rem); line-height: 1.4; }
h4,.h4 { font-size: 1.0625rem; line-height: 1.55; font-weight: 600; }
h5,.h5 { font-size: 1.05rem; }
h6,.h6 { font-family: var(--ms-ui-font); text-transform: uppercase; letter-spacing: .12em;
    font-size: .8rem; font-weight: 600; color: var(--ms-taupe); }
h1,h2,h3,h4,h5 { margin-bottom: var(--ms-space-3); }

/* Body rhythm */
p { margin: 0 0 var(--ms-space-3); }
p:last-child { margin-bottom: 0; }
ul, ol { margin: 0 0 var(--ms-space-3) 1.25rem; }
li { margin-bottom: .35rem; }
.text-intro { font-size: 1.15rem; line-height: 1.7; color: var(--ms-charcoal-2); margin-bottom: var(--ms-space-4); }
.text-muted { color: var(--ms-taupe) !important; }

a { color: var(--ms-sage-text); text-decoration: none; transition: color var(--ms-dur) var(--ms-ease); }
a:hover { color: var(--ms-charcoal); }
:focus-visible { outline: 2px solid var(--ms-sage); outline-offset: 2px; }

/* Mobile: kill the grey tap-flash and the persistent focus box left after a touch,
   but KEEP keyboard focus (:focus-visible above) for accessibility */
* { -webkit-tap-highlight-color: transparent; }
.navbar-toggler:focus, .navbar-toggler:active { box-shadow: none; outline: none; }
a:focus:not(:focus-visible),
button:focus:not(:focus-visible),
.btn:focus:not(:focus-visible),
.nav-link:focus:not(:focus-visible) { outline: none; box-shadow: none; }

/* Tap targets */
.btn, button, a.btn, input[type="button"], input[type="submit"] { min-height: 44px; }

/* ===== Buttons — minimal / flat (reference) ===== */
.btn { font-family: var(--ms-ui-font); font-weight: 500; letter-spacing: .03em; text-transform: none;
    font-size: .85rem; border-radius: 0;
    padding: .7rem 1.6rem; box-shadow: none;
    transition: background-color var(--ms-dur) var(--ms-ease), color var(--ms-dur) var(--ms-ease),
    border-color var(--ms-dur) var(--ms-ease); }
.btn:disabled, .btn.disabled { opacity:.5; }
.btn-lg { padding: .9rem 2.2rem; font-size: .82rem; min-height: 52px; }
.btn-primary { --bs-btn-bg:#BFA489; --bs-btn-border-color:#BFA489;
    --bs-btn-hover-bg:#AD8B68; --bs-btn-hover-border-color:#AD8B68;
    --bs-btn-active-bg:#9d7d5c; --bs-btn-active-border-color:#9d7d5c; --bs-btn-color:#fff; }
.btn-outline-primary { --bs-btn-color:#262626; --bs-btn-border-color:#BFA489;
    --bs-btn-hover-bg:#BFA489; --bs-btn-hover-border-color:#BFA489; --bs-btn-hover-color:#fff; }
.btn-success { --bs-btn-bg:#32A88B; --bs-btn-border-color:#32A88B;
    --bs-btn-hover-bg:#2b9079; --bs-btn-hover-border-color:#2b9079; --bs-btn-color:#fff; }
.btn-gold { background:var(--ms-charcoal); border:1px solid var(--ms-charcoal); color:#fff; }
.btn-gold:hover { background:#000; border-color:#000; color:#fff; }
.btn-ghost { background:transparent; border:1px solid var(--ms-sage); color:var(--ms-sage-text); box-shadow:none; }
.btn-ghost:hover { background:var(--ms-sage); color:#fff; }

/* ===== Cards — flat editorial ===== */
.card { border:1px solid var(--ms-border); border-radius: var(--bs-border-radius);
    box-shadow: none; background: var(--ms-white); }
.ms-card { background:var(--ms-white); border:1px solid var(--ms-border);
    border-radius: var(--bs-border-radius); box-shadow: none; padding: var(--ms-space-4); }
.card-featured { background: var(--ms-cream); border-color: var(--ms-border); }

.product-card { background:var(--ms-white); border:1px solid var(--ms-border);
    border-radius:var(--bs-border-radius); overflow:hidden; height:100%;
    transition: border-color var(--ms-dur) var(--ms-ease); }
.product-card:hover { border-color:var(--ms-sage); }
.product-card__media { aspect-ratio:3/4; background:var(--ms-cream); overflow:hidden; }
.product-card__media img { width:100%; height:100%; object-fit:cover; display:block;
    transition: transform .6s var(--ms-ease); }
.product-card:hover .product-card__media img { transform: scale(1.04); }
.product-card__body { padding:1.1rem 1rem; text-align:center; }
.product-card__title { font-family:var(--ms-heading-font); font-size:1.15rem; font-weight:600;
    color:var(--ms-charcoal); margin:0 0 .2rem; }
.product-card__meta { font-size:.78rem; color:var(--ms-taupe); margin:0; }
.product-card__price { color:var(--ms-charcoal); font-weight:600; margin:.4rem 0 0; }
@media (hover:none){ .product-card:hover .product-card__media img { transform:none; } }

/* ===== Forms ===== */
.form-label { font-size:.78rem; font-weight:600; letter-spacing:.05em;
    text-transform:uppercase; color:var(--ms-charcoal-2); margin-bottom:.45rem; }
.form-control, .form-select { min-height:48px; font-size:1rem; background:var(--ms-white);
    border:1px solid var(--ms-border-2); border-radius:var(--bs-border-radius-sm);
    color:var(--ms-charcoal); transition: border-color var(--ms-dur) var(--ms-ease), box-shadow var(--ms-dur) var(--ms-ease); }
.form-control::placeholder { color:var(--ms-taupe); opacity:.7; }
.form-control:focus, .form-select:focus { border-color:var(--ms-sage);
    box-shadow:0 0 0 .2rem rgba(111,140,63,.18); }
.form-control:disabled, .form-control[readonly] { background:var(--ms-cream);
    border-color:var(--ms-border); color:var(--ms-charcoal-2); }
textarea.form-control { min-height:120px; resize:vertical; }
.form-control-lg, .form-select-lg { min-height:52px; }
.is-invalid { border-color:#B0413B !important; }
.invalid-feedback { color:#B0413B; }
/* iOS: 16px inputs prevent auto-zoom on focus */
@media (max-width:767.98px){ .form-control, .form-select { font-size:16px; } }

/* ===== Alerts (brand-muted) ===== */
.alert { border:0; border-left:3px solid; border-radius:var(--bs-border-radius-sm); }
.alert-success { background:#ECF3EB; border-color:#5C8A5A; color:#3f6a3e; }
.alert-danger  { background:#F7ECEA; border-color:#B0413B; color:#8f312c; }
.alert-warning { background:#F7F0E2; border-color:#B8893B; color:#8a6428; }
.alert-info    { background:#EAF1F3; border-color:#5C7D8A; color:#3f5b66; }

/* ===== Badges ===== */
.badge-soft { background:var(--ms-sage-50); color:var(--ms-sage-text); border-radius:999px;
    text-transform:uppercase; letter-spacing:.05em; font-size:.7rem; padding:.35em .8em; }

/* ==========================================================================
   Header / navigation
   ========================================================================== */
.site-header { background:var(--ms-white); border-bottom:1px solid var(--ms-border);
    box-shadow:0 1px 0 rgba(43,42,38,.02); }
.site-header .navbar { padding-top:.85rem; padding-bottom:.85rem; }
.site-header .navbar-brand img { height:clamp(40px, 9vw, 58px); width:auto; }
.site-header .nav-link { font-family:var(--bs-body-font-family); color:var(--ms-charcoal); font-weight:500; letter-spacing:1px;
    text-transform:uppercase; font-size:1rem; position:relative; padding-left:.8rem; padding-right:.8rem; }
.site-header .nav-link:not(.dropdown-toggle)::after { content:''; position:absolute; left:.85rem; right:.85rem; bottom:.35rem;
    height:1.5px; background:var(--ms-sage); transform:scaleX(0); transform-origin:left;
    transition:transform var(--ms-dur) var(--ms-ease); }
.site-header .nav-link:hover, .site-header .nav-link.active { color:var(--ms-sage-text); }
.site-header .nav-link:not(.dropdown-toggle):hover::after,
.site-header .nav-link:not(.dropdown-toggle).active::after { transform:scaleX(1); }
.dropdown-menu { border:1px solid var(--ms-border); border-radius:var(--bs-border-radius);
    box-shadow:var(--ms-shadow-md); padding:.65rem 0; }
.dropdown-item { padding:.5rem 1.25rem; white-space:normal; word-break:break-word; overflow-wrap:anywhere;
    transition:background var(--ms-dur) var(--ms-ease), color var(--ms-dur) var(--ms-ease), padding-left var(--ms-dur) var(--ms-ease); }
.dropdown-item:hover { background:var(--ms-sage-50); color:var(--ms-sage-text); padding-left:1.45rem; }
.dropdown-header { color:var(--ms-sage-text); font-weight:700; letter-spacing:.06em; font-size:.74rem; padding:.5rem 1.25rem .35rem; }
.mansard-mega { min-width:min(900px, 96vw); max-width:calc(100vw - 2rem);
    padding:1.5rem 1.25rem !important; left:0; right:auto; }
.mansard-mega .dropdown-item { padding-top:.35rem; padding-bottom:.35rem; white-space:normal; }
.mansard-mega .col-md-4 { min-width:0; }
/* hover-open dropdowns on large screens (luxury feel) */
@media (min-width:992px){
    .site-header .nav-item.dropdown:hover > .dropdown-menu { display:block; margin-top:0; }
}
.cart-count { font-variant-numeric: tabular-nums; }
.lang-switch img { width:22px; height:auto; border:1px solid var(--ms-border); }
.lang-switch a { display:inline-flex; align-items:center; justify-content:center;
    min-width:44px; min-height:44px; padding:.4rem; border-radius:var(--bs-border-radius-sm); }
.lang-switch a.opacity-100 { box-shadow:inset 0 -2px 0 var(--ms-sage); }

/* Offcanvas mobile menu — clean, brand-aligned */
.offcanvas { width:min(360px, 86vw) !important; }
.offcanvas-header { border-bottom:1px solid var(--ms-border); padding:1rem 1.25rem; }
.offcanvas-brand img { height:38px; width:auto; display:block; }
.offcanvas-body { padding:0 1.25rem 1.5rem; }

/* top-level rows (Home, Face, SPA, Body, Salon, Brand, Contact) share one look */
.offcanvas .mnav-top,
.offcanvas .accordion-button {
    font-family:var(--ms-ui-font); font-weight:500; text-transform:uppercase;
    letter-spacing:.08em; font-size:.92rem; color:var(--ms-charcoal);
    background:transparent; box-shadow:none; border:0;
    padding:.95rem .15rem; min-height:52px; width:100%; }
.offcanvas .mnav-top { display:flex; align-items:center; text-decoration:none;
    border-bottom:1px solid var(--ms-border); }
.offcanvas .accordion-item { background:transparent; border:0; border-bottom:1px solid var(--ms-border); }
.offcanvas .accordion-header { margin:0; }
.offcanvas .accordion-button:not(.collapsed){ color:var(--ms-sage-text); background:transparent; }
.offcanvas .accordion-button:focus { box-shadow:none; border:0; }
.offcanvas .accordion-button::after { width:.9rem; height:.9rem; background-size:.9rem; }
.offcanvas .mnav-top:hover, .offcanvas .mnav-top.active,
.offcanvas .accordion-button:hover { color:var(--ms-sage-text); }

/* sub-items inside an accordion (product / ritual links) */
.offcanvas .accordion-body { padding:.15rem 0 .85rem; }
.offcanvas .accordion-body a { display:flex; align-items:center; min-height:40px; font-size:.9rem;
    color:var(--ms-charcoal-2); padding:.1rem 0 .1rem .9rem; border-left:2px solid transparent;
    text-decoration:none; }
.offcanvas .accordion-body a:hover { color:var(--ms-sage-text); border-left-color:var(--ms-sage); }
.offcanvas .sub-label { font-family:var(--ms-ui-font); font-size:.7rem; font-weight:600;
    text-transform:uppercase; letter-spacing:.1em; color:var(--ms-taupe); margin:.85rem 0 .3rem; }

/* utility block (cart / account / logout) + language */
.mnav-utility { margin-top:1.5rem; padding-top:1rem; border-top:1px solid var(--ms-border);
    display:flex; flex-direction:column; }
.offcanvas .mnav-util { display:flex; align-items:center; gap:.7rem; min-height:46px;
    font-family:var(--ms-ui-font); font-size:.95rem; color:var(--ms-charcoal); text-decoration:none; }
.offcanvas .mnav-util i { font-size:1.1rem; color:var(--ms-sage-text); width:1.3rem; text-align:center; }
.offcanvas .mnav-util:hover { color:var(--ms-sage-text); }
.mnav-lang { margin-top:1.25rem; padding-top:1rem; border-top:1px solid var(--ms-border); }
.mnav-lang .lang-switch { display:flex; gap:.5rem; }

/* ==========================================================================
   Footer
   ========================================================================== */
.site-footer { background:var(--ms-cream); color:var(--ms-charcoal-2);
    border-top:3px solid var(--ms-sage); }
.site-footer a { color:var(--ms-charcoal-2); text-decoration:none;
    transition:color var(--ms-dur) var(--ms-ease); }
.site-footer a:hover { color:var(--ms-sage-text); }
/* logo is a white-background JPG — multiply blends the white into the cream footer */
.footer-logo { height:46px; width:auto; mix-blend-mode:multiply; }
.footer-address { font-style:normal; color:var(--ms-taupe); line-height:1.7; font-size:.9rem; margin:0; }
.footer-heading { font-family:var(--ms-ui-font); font-size:.78rem; text-transform:uppercase;
    letter-spacing:.14em; color:var(--ms-charcoal); margin-bottom:1rem; }
.footer-links li { margin-bottom:.55rem; font-size:.92rem; }
.site-footer .social { display:flex; gap:.6rem; }
.site-footer .social a { font-size:1.2rem; color:var(--ms-charcoal); width:40px; height:40px;
    display:inline-flex; align-items:center; justify-content:center; border:1px solid var(--ms-border);
    border-radius:50%; transition:all var(--ms-dur) var(--ms-ease); }
.site-footer .social a:hover { color:#fff; background:var(--ms-sage); border-color:var(--ms-sage); }
.footer-pay { max-width:200px; width:100%; height:auto; }
.footer-bottom { border-top:1px solid var(--ms-border); margin-top:2.5rem; padding-top:1.5rem;
    text-align:center; font-size:.85rem; color:var(--ms-taupe); }

/* ==========================================================================
   Responsive data tables → stacked cards on mobile
   Add class .ms-table (+ .ms-stack) to <table>, and data-label="" on <td>.
   ========================================================================== */
.ms-table { width:100%; background:var(--ms-white); border-collapse:collapse; }
.ms-table thead th { font-size:.74rem; text-transform:uppercase; letter-spacing:.06em;
    color:var(--ms-charcoal); font-weight:700; border-bottom:2px solid var(--ms-border-2); padding:.9rem .75rem; }
.ms-table tbody td, .ms-table tfoot td { padding:.9rem .75rem; border-bottom:1px solid var(--ms-border);
    vertical-align:middle; color:var(--ms-charcoal-2); }
@media (min-width:768px){
    .ms-table tbody tr { transition:background var(--ms-dur) var(--ms-ease); }
    .ms-table tbody tr:hover { background:var(--ms-sage-50); }
}

@media (max-width:767.98px){
    .ms-table.ms-stack thead { position:absolute; width:1px; height:1px; padding:0;
        margin:-1px; overflow:hidden; clip:rect(0 0 0 0); border:0; }
    .ms-table.ms-stack tbody, .ms-table.ms-stack tfoot { display:block; }
    .ms-table.ms-stack tr { display:block; margin-bottom:1rem; border:1px solid var(--ms-border);
        border-radius:var(--bs-border-radius); background:var(--ms-white);
        box-shadow:var(--ms-shadow-sm); padding:.25rem .9rem; }
    .ms-table.ms-stack td { display:flex; justify-content:space-between; align-items:center;
        gap:1rem; text-align:right; border-bottom:1px solid var(--ms-border); padding:.7rem 0; }
    .ms-table.ms-stack tr td:last-child { border-bottom:0; }
    .ms-table.ms-stack td::before { content:attr(data-label); font-weight:600; color:var(--ms-taupe);
        text-transform:uppercase; font-size:.7rem; letter-spacing:.05em; text-align:left; }
    .ms-table.ms-stack td[data-label=""]::before,
    .ms-table.ms-stack td:not([data-label])::before { content:none; }
}

/* Quantity stepper */
.ms-stepper { display:inline-flex; align-items:center; gap:.25rem; }
.ms-stepper .btn { min-height:44px; min-width:44px; padding:0 .6rem; line-height:1; }
.ms-stepper input { width:3.5rem; text-align:center; border:1px solid var(--ms-border-2);
    border-radius:var(--bs-border-radius-sm); min-height:44px; background:var(--ms-white); }

/* Scroll panels (terms boxes) */
.ms-scroll-panel { max-height:min(50vh, 420px); overflow-y:auto; background:var(--ms-cream);
    border:1px solid var(--ms-border); border-radius:var(--bs-border-radius-sm); padding:1rem; }

/* ==========================================================================
   Content pages — restyle + responsive compat for legacy structural classes
   (legacy Joomla template CSS removed; these provide the styling now)
   ========================================================================== */
#system { padding-top: .25rem; }
.content-page { max-width:820px; margin:0 auto; padding-bottom: var(--ms-space-5); }
.content-page p, #system p, #system li { font-size:1.0625rem; }
.content-page p, .content-page li { max-width:68ch; }
/* unify legacy content: never justify on any screen (was a desktop "old-web" tell) */
#system [style*="justify"] { text-align:left !important; }
.content-img, .product_img img, #system img.inset-right {
    max-width:100%; height:auto; border-radius:var(--bs-border-radius); }

/* product detail image — clean, consistent, no crop (minimal frame) */
.product-hero { background:var(--ms-white); border:1px solid var(--ms-border);
    border-radius:var(--bs-border-radius); padding:clamp(1rem,3vw,2.5rem);
    display:flex; align-items:center; justify-content:center; }
.product-hero img { max-height:520px; width:auto; object-fit:contain; }

/* legacy two-column article layout (desktop side-by-side, mobile stacked) */
.item .content, .item .content.clearfix { display:flex; flex-wrap:wrap; gap:var(--ms-space-5); align-items:flex-start; }
.product_left, .contact_left { flex:1 1 340px; min-width:0; }
.product_right, .contact_right { flex:1 1 320px; min-width:0; text-align:center; }
/* integrated inset image (rounded + soft shadow, not a bare floated jpg) */
.inset-right { float:right; margin:.25rem 0 1rem 1.75rem; max-width:40%;
    border-radius:var(--bs-border-radius); }
.title { font-family:var(--ms-heading-font); font-weight:600; margin:0 0 var(--ms-space-4); }

/* ---- Clean page scaffolding (reference editorial look) ---- */
.page-header { margin-bottom: var(--ms-space-5); }
.page-header.text-center { margin-left:auto; margin-right:auto; }
.page-header h1, .page-header .title { margin-bottom: var(--ms-space-2); }
.page-header .lead, .page-header p { color: var(--ms-taupe); max-width: 70ch; margin: 0; }
.page-header.text-center p { margin-left:auto; margin-right:auto; }

/* clean content image (replaces floated bare .inset-right) */
.content-figure { margin: 0 0 var(--ms-space-4); }
.content-figure img { display:block; width:100%; height:auto; border-radius:var(--bs-border-radius); }
.content-figure figcaption { font-size:.85rem; color:var(--ms-taupe); margin-top:.5rem; text-align:center; }

/* long legal documents (delivery / distance) */
.legal-doc { max-width: 860px; }
.legal-doc h2 { font-size: 1.4rem; margin-top: var(--ms-space-5); }
.legal-doc h3 { font-size: 1.05rem; font-weight:600; color: var(--ms-charcoal);
    margin-top: var(--ms-space-4); margin-bottom: var(--ms-space-2); }
.legal-doc p { margin-bottom: var(--ms-space-2); }
.legal-doc address { font-style: normal; color: var(--ms-charcoal-2); margin: var(--ms-space-2) 0 var(--ms-space-4); }

/* legacy form/text class compat (avoid per-file churn) */
.formIletisim { width: 100%; }
.urunDetayAciklama, .urunDetayAciklama td { color: var(--ms-charcoal-2); }

/* mobile: stack columns, un-float images, full-width Joomla width classes */
@media (max-width:767.98px){
    .product_left, .product_right, .contact_left, .contact_right,
    .width33, .width50, .width100, [class*="width"] { width:100% !important; flex-basis:100% !important; float:none !important; }
    .inset-right { float:none; display:block; margin:0 auto 1rem; max-width:100%; }
    .item .content, .item .content.clearfix { flex-direction:column; gap:1rem; }
    .product_right, .contact_right { order:-1; }
    /* legacy single-cell layout tables → full-width block ONLY on mobile */
    #system table:not(.table):not(.ms-table) td { display:block; width:100%; }
}

/* link lists (face category grid etc.) */
.ms-link-list { list-style:none; padding:0; margin:0; }
.ms-link-list li { padding:.3rem 0; border-bottom:1px solid var(--ms-border); }
.ms-link-list li:last-child { border-bottom:0; }

/* check-mark lists (brand / values, reference "uk-list-large" style) */
.ms-check-list { list-style:none; padding:0; margin:0 0 var(--ms-space-3); }
.ms-check-list li { position:relative; padding:.45rem 0 .45rem 1.9rem; line-height:1.55; }
.ms-check-list li + li { border-top:1px solid var(--ms-border); }
.ms-check-list li::before {
    content:""; position:absolute; left:0; top:.7em; width:1.05rem; height:1.05rem;
    transform:translateY(-50%); background-repeat:no-repeat; background-position:center;
    background-size:contain;
    background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16' fill='none' stroke='%23BFA489' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M13.5 4.5 6 12 2.5 8.5'/%3E%3C/svg%3E");
}

/* offscreen honeypot helper (keep focusable-but-hidden) */
.ms-hp { position:absolute; left:-9999px; top:auto; width:1px; height:1px; overflow:hidden; }

/* generic section rhythm — generous whitespace (reference) */
.ms-section { padding: 40px 0; }
@media (min-width:992px){ .ms-section { padding: 70px 0; } }
.ms-section + .ms-section { padding-top: 0; }
.ms-section--cream { background: var(--ms-cream); }

/* ==========================================================================
   Color / text utilities (replace scattered inline styles)
   ========================================================================== */
.text-gold { color: var(--ms-sage-text) !important; }
.text-sage { color: var(--ms-sage-text) !important; }
.price { color: var(--ms-charcoal); font-weight: 600; }
.font_color { color: var(--ms-sage-text); font-weight: 600; }
/* readonly quantity display used in checkout summaries */
.ms-input-readonly { width: 3.5rem; text-align: center; background: transparent;
    border: 0; color: var(--ms-charcoal); }
/* empty-state card (e.g. empty cart) */
.ms-empty { text-align: center; padding: clamp(2rem, 1rem + 5vw, 4rem) 1rem; color: var(--ms-taupe); }

/* ==========================================================================
   Luxury components: section header, divider, breadcrumb, image ratios
   ========================================================================== */
.section-header { text-align:center; max-width:680px; margin:0 auto var(--ms-space-6); }
.section-header .eyebrow { display:block; font-family:var(--ms-ui-font); font-size:.74rem; font-weight:600; letter-spacing:.2em;
    text-transform:uppercase; color:var(--ms-sage-text); margin-bottom:.75rem; }
.section-header h2, .section-header .h2 { margin-bottom:var(--ms-space-3); }
.section-header p { color:var(--ms-taupe); margin:0 auto; }
.section-header::after { content:''; display:block; width:48px; height:2px; margin:var(--ms-space-4) auto 0;
    background:var(--ms-sage); }

.divider { border:0; height:1px; margin:var(--ms-space-5) 0;
    background:linear-gradient(90deg, transparent, var(--ms-border), transparent); }

.breadcrumb { background:transparent; padding:0; margin-bottom:var(--ms-space-4); font-size:.85rem; }
.breadcrumb-item, .breadcrumb-item a { color:var(--ms-taupe); }
.breadcrumb-item.active { color:var(--ms-charcoal); }
.breadcrumb-item + .breadcrumb-item::before { color:var(--ms-border-2); }

.img-ratio-1x1, .img-ratio-4x3, .img-ratio-3x4, .img-ratio-16x9 { display:block; overflow:hidden;
    border-radius:var(--bs-border-radius); background:var(--ms-cream); }
.img-ratio-1x1 { aspect-ratio:1/1; } .img-ratio-4x3 { aspect-ratio:4/3; }
.img-ratio-3x4 { aspect-ratio:3/4; } .img-ratio-16x9 { aspect-ratio:16/9; }
.img-ratio-1x1 > img, .img-ratio-4x3 > img, .img-ratio-3x4 > img, .img-ratio-16x9 > img {
    width:100%; height:100%; object-fit:cover; display:block; }

/* ==========================================================================
   Mobile sticky "add to cart" bar (product page, < lg)
   ========================================================================== */
.ms-buybar {
    position: fixed; left: 0; right: 0; bottom: 0; z-index: 1030;
    background: var(--ms-white); border-top: 1px solid var(--ms-border);
    box-shadow: 0 -4px 16px rgba(43,42,38,.10);
    display: flex; align-items: center; gap: 1rem;
    padding: .6rem .9rem; padding-bottom: calc(.6rem + env(safe-area-inset-bottom));
}
.ms-buybar .price { margin: 0; font-size: 1.1rem; white-space: nowrap; }
.ms-buybar .btn { flex: 1; }
.ms-buybar-spacer { height: 84px; }
@media (min-width: 992px) { .ms-buybar, .ms-buybar-spacer { display: none !important; } }

/* ==========================================================================
   Bootstrap 3/4 + legacy class compatibility (avoids per-file churn)
   ========================================================================== */
.form-group { margin-bottom: 1rem; }
.center { text-align: center; }
.text-right { text-align: right !important; }
.pull-right { float: right !important; }
.pull-left { float: left !important; }
.input-lg { min-height: 52px; font-size: 1.0625rem; }
.btn-xs { padding: .4rem .8rem; font-size: .8125rem; min-height: 44px; display: inline-flex; align-items: center; }
.well { background: var(--ms-cream); border: 1px solid var(--ms-border);
    border-radius: var(--bs-border-radius); padding: 1.25rem; }
.img-responsive { max-width: 100%; height: auto; }
.m-auto { margin-left: auto; margin-right: auto; display: block; }
.mb-30 { margin-bottom: 1.5rem; }
.mt-30 { margin-top: 1.25rem; }
.urunDetayBaslik { font-family: var(--ms-heading-font); font-weight: 600; }
/* legacy error lists that wrapped <li> in stray <tr><td> still read as a list */
#system ul tr, #system ul td { display: block; }

/* legacy single-cell LAYOUT tables on content pages → full width, no overflow
   (real data tables opt out via .table / .ms-table; td→block is mobile-only above) */
#system table:not(.table):not(.ms-table) { width: 100%; max-width: 100%; border-collapse: collapse; }
