:root {
    --orange: #f56d13;
    --orange-dark: #d94e00;
    --orange-soft: #fff1e8;
    --ink: #111216;
    --muted: #68707c;
    --line: #e7e9ed;
    --paper: #ffffff;
    --surface: #f6f7f9;
    --success: #0e8d5b;
    --danger: #c93f3f;
    --radius: 18px;
    --shadow: 0 18px 50px rgba(17, 18, 22, .08);
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body { margin: 0; color: var(--ink); background: var(--paper); font-family: "DM Sans", sans-serif; line-height: 1.6; }
img { max-width: 100%; display: block; }
a { color: inherit; text-decoration: none; }
button, input, select, textarea { font: inherit; }
button { cursor: pointer; }
h1, h2, h3, h4 { margin: 0 0 .65rem; font-family: "Manrope", sans-serif; line-height: 1.16; letter-spacing: -.035em; }
p { margin: 0 0 1rem; }
.container { width: min(1180px, calc(100% - 40px)); margin-inline: auto; }
.section { padding: 82px 0; }
.section-soft { background: var(--surface); }
.section-dark { color: white; background: var(--ink); }
.home-sections { display: flex; flex-direction: column; }
.eyebrow { display: inline-flex; align-items: center; gap: 8px; margin-bottom: 12px; color: var(--orange); font-size: .77rem; font-weight: 800; letter-spacing: .14em; text-transform: uppercase; }
.eyebrow::before { width: 26px; height: 2px; content: ""; background: currentColor; }
.eyebrow.light { color: #ffd5bc; }
.section-heading { display: flex; align-items: end; justify-content: space-between; gap: 24px; margin-bottom: 34px; }
.section-heading h2 { max-width: 760px; font-size: clamp(1.8rem, 3.5vw, 3rem); }
.section-heading p { max-width: 560px; color: var(--muted); }
.text-link { color: var(--orange-dark); font-weight: 700; white-space: nowrap; }

.topbar { color: #e8e8e8; background: #0b0b0d; font-size: .78rem; }
.topbar-inner { min-height: 34px; display: flex; align-items: center; justify-content: space-between; gap: 20px; }
.topbar a:hover { color: var(--orange); }
.topbar-dot { margin: 0 8px; color: #555; }
.site-header { position: sticky; top: 0; z-index: 50; border-bottom: 1px solid rgba(0, 0, 0, .07); background: rgba(255, 255, 255, .96); backdrop-filter: blur(18px); }
.header-inner { min-height: 82px; display: flex; align-items: center; gap: 26px; }
.brand { flex: 0 0 136px; }
.brand img { width: 136px; height: 58px; object-fit: contain; }
.main-nav { flex: 1; display: flex; align-items: center; justify-content: center; gap: 5px; }
.main-nav > a, .nav-dropdown > button { padding: 11px 10px; border: 0; color: #31343a; background: transparent; font-size: .91rem; font-weight: 700; }
.main-nav > a:hover, .main-nav > a.active, .nav-dropdown > button:hover { color: var(--orange-dark); }
.nav-dropdown { position: relative; }
.dropdown-menu { position: absolute; top: calc(100% + 16px); left: 50%; width: 330px; padding: 12px; visibility: hidden; transform: translate(-50%, 10px); border: 1px solid var(--line); border-radius: 16px; opacity: 0; background: white; box-shadow: var(--shadow); transition: .2s ease; }
.dropdown-menu::before { position: absolute; top: -17px; left: 0; width: 100%; height: 20px; content: ""; }
.nav-dropdown:hover .dropdown-menu, .nav-dropdown.open .dropdown-menu { visibility: visible; transform: translate(-50%, 0); opacity: 1; }
.dropdown-menu a { display: block; padding: 11px 12px; border-radius: 10px; }
.dropdown-menu a:hover { color: var(--orange-dark); background: var(--orange-soft); }
.dropdown-menu strong, .dropdown-menu small { display: block; }
.dropdown-menu small { margin-top: 2px; color: var(--muted); font-size: .76rem; }
.dropdown-menu.compact { width: 245px; }
.header-actions { display: flex; align-items: center; gap: 12px; white-space: nowrap; }
.login-link { font-size: .88rem; font-weight: 700; }
.login-link:hover { color: var(--orange-dark); }
.mobile-menu-button { display: none; width: 42px; height: 42px; padding: 10px; border: 1px solid var(--line); border-radius: 10px; background: white; }
.mobile-menu-button span { display: block; height: 2px; margin: 4px 0; background: var(--ink); }

.btn { min-height: 46px; display: inline-flex; align-items: center; justify-content: center; gap: 9px; padding: 0 20px; border: 1px solid transparent; border-radius: 11px; font-weight: 800; transition: .2s ease; }
.btn:hover { transform: translateY(-1px); }
.btn-small { min-height: 40px; padding-inline: 15px; font-size: .85rem; }
.btn-primary { color: white; background: var(--orange); box-shadow: 0 8px 24px rgba(245, 109, 19, .24); }
.btn-primary:hover { background: var(--orange-dark); }
.btn-dark { color: white; background: var(--ink); }
.btn-ghost { border-color: var(--line); background: white; }
.btn-white { color: var(--ink); background: white; }
.btn-like.active { color: white; border-color: var(--orange); background: var(--orange); }
.btn-like[aria-busy="true"] { cursor: wait; opacity: .72; }
.hero-ghost { color: white; border-color: rgba(255,255,255,.4); background: rgba(255,255,255,.06); }

.flash { margin-top: 18px; padding: 14px 18px; border-radius: 12px; }
.flash-success { color: #075e3e; border: 1px solid #a6dfc7; background: #ecfaf4; }
.flash-error { color: #852b2b; border: 1px solid #efb7b7; background: #fff1f1; }
.flash ul { margin: 5px 0 0 20px; }
.site-toast { position: fixed; right: 22px; bottom: 22px; z-index: 100; max-width: min(390px, calc(100vw - 40px)); padding: 13px 18px; visibility: hidden; transform: translateY(14px); border-radius: 12px; opacity: 0; color: white; background: #075e3e; box-shadow: 0 14px 40px rgba(0,0,0,.2); font-size: .9rem; font-weight: 700; transition: .2s ease; }
.site-toast[data-type="error"] { background: #852b2b; }
.site-toast.show { visibility: visible; transform: translateY(0); opacity: 1; }

.hero { overflow: hidden; position: relative; min-height: 650px; display: flex; align-items: center; color: white; background: #101114; }
.hero::after { position: absolute; inset: 0; content: ""; background: linear-gradient(90deg, rgba(10, 10, 12, .96) 0%, rgba(10, 10, 12, .78) 48%, rgba(10, 10, 12, .2) 100%); }
.hero-media { position: absolute; inset: 0 0 0 42%; }
.hero-media img { width: 100%; height: 100%; object-fit: cover; opacity: .75; }
.hero-content { position: relative; z-index: 2; max-width: 730px; padding: 95px 0; }
.hero h1 { margin-bottom: 22px; font-size: clamp(2.7rem, 6vw, 5.7rem); line-height: 1.02; }
.hero h1 span { color: var(--orange); }
.hero-lead { max-width: 650px; margin-bottom: 30px; color: #d4d6da; font-size: 1.12rem; }
.hero-actions { display: flex; flex-wrap: wrap; gap: 12px; margin-top: 24px; }
.hero-search { max-width: 720px; display: grid; grid-template-columns: 1fr auto; gap: 8px; padding: 8px; border-radius: 15px; background: white; box-shadow: 0 20px 60px rgba(0, 0, 0, .25); }
.hero-search input { min-width: 0; padding: 11px 14px; border: 0; outline: 0; color: var(--ink); }
.hero-proof { display: flex; flex-wrap: wrap; gap: 26px; margin-top: 30px; color: #d4d6da; font-size: .86rem; }
.hero-proof strong { display: block; color: white; font-size: 1.2rem; }
.home-layout-editorial .hero { min-height: 570px; }
.home-layout-editorial .hero-content { max-width: 830px; }
.home-layout-editorial .hero h1 { font-family: Georgia, serif; font-weight: 700; }
.home-layout-editorial .article-grid { grid-template-columns: repeat(2, 1fr); }
.home-layout-showcase .hero { min-height: 760px; }
.home-layout-showcase .hero-content { max-width: 860px; margin-inline: auto; text-align: center; }
.home-layout-showcase .hero-search { margin-inline: auto; }
.home-layout-showcase .hero-actions, .home-layout-showcase .hero-proof { justify-content: center; }

.type-grid { display: grid; grid-template-columns: repeat(5, 1fr); gap: 14px; }
.type-card { min-height: 190px; display: flex; flex-direction: column; justify-content: space-between; padding: 24px; border: 1px solid var(--line); border-radius: var(--radius); background: white; transition: .2s ease; }
.type-card:hover { transform: translateY(-5px); border-color: #ffc9a7; box-shadow: var(--shadow); }
.type-icon { width: 48px; height: 48px; display: grid; place-items: center; border-radius: 13px; color: var(--orange-dark); background: var(--orange-soft); font-size: 1.3rem; font-weight: 800; }
.type-card h3 { margin: 18px 0 6px; font-size: 1.08rem; }
.type-card p { color: var(--muted); font-size: .84rem; }
.type-card small { color: var(--orange-dark); font-weight: 800; }

.listing-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 22px; }
.listing-card { overflow: hidden; border: 1px solid var(--line); border-radius: var(--radius); background: white; transition: .22s ease; }
.listing-card:hover { transform: translateY(-4px); box-shadow: var(--shadow); }
.card-style-elevated .listing-card, .card-style-elevated .article-card, .card-style-elevated .artwork-card { border-color: transparent; box-shadow: var(--shadow); }
.card-style-minimal .listing-card, .card-style-minimal .article-card, .card-style-minimal .artwork-card { border-color: transparent; border-radius: 5px; box-shadow: none; }
.card-style-minimal .listing-card-body, .card-style-minimal .article-body, .card-style-minimal .artwork-body { padding-inline: 4px; }
.listing-card-image { overflow: hidden; position: relative; aspect-ratio: 1.5; display: block; background: #eceef1; }
.listing-card-image img { width: 100%; height: 100%; object-fit: cover; transition: transform .35s ease; }
.listing-card:hover .listing-card-image img { transform: scale(1.035); }
.card-type, .card-featured { position: absolute; top: 14px; padding: 6px 9px; border-radius: 8px; font-size: .7rem; font-weight: 800; }
.card-type { left: 14px; color: white; background: rgba(17, 18, 22, .8); backdrop-filter: blur(8px); }
.card-featured { right: 14px; color: white; background: var(--orange); }
.listing-card-body { padding: 20px; }
.card-meta, .article-meta { display: flex; justify-content: space-between; gap: 10px; color: var(--muted); font-size: .74rem; }
.listing-card h3 { margin: 10px 0; font-size: 1.08rem; }
.listing-card h3 a:hover, .article-card h3 a:hover { color: var(--orange-dark); }
.card-price { margin: 13px 0; color: var(--orange-dark); font-family: "Manrope", sans-serif; font-size: 1.2rem; font-weight: 800; }
.card-excerpt { min-height: 45px; color: var(--muted); font-size: .86rem; }
.card-stats { display: flex; gap: 16px; padding-top: 14px; border-top: 1px solid var(--line); color: var(--muted); font-size: .76rem; font-weight: 700; }

.article-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 22px; }
.article-card { overflow: hidden; border: 1px solid var(--line); border-radius: var(--radius); background: white; }
.article-image { aspect-ratio: 1.45; display: block; background: #eee; }
.article-image img { width: 100%; height: 100%; object-fit: cover; }
.article-body { padding: 20px; }
.article-meta span:first-child { color: var(--orange-dark); font-weight: 800; text-transform: capitalize; }
.article-card h3 { margin: 12px 0; font-size: 1.08rem; }
.article-card p { color: var(--muted); font-size: .85rem; }

.ad-section { padding: 34px 0 0; }
.ad-slot { overflow: hidden; position: relative; margin-bottom: 28px; border: 1px solid var(--line); border-radius: 16px; background: #f0f1f3; box-shadow: 0 12px 30px rgba(17,18,22,.06); }
.ad-slot-track { position: relative; }
.ad-banner { display: none; position: relative; }
.ad-banner.active { display: block; }
.ad-banner a, .ad-banner picture { display: block; }
.ad-banner img { width: 100%; aspect-ratio: 3.2; object-fit: cover; }
.ad-label { position: absolute; top: 9px; right: 9px; padding: 3px 7px; border-radius: 5px; color: white; background: rgba(0,0,0,.65); font-size: .62rem; font-weight: 800; letter-spacing: .06em; text-transform: uppercase; }
.ad-dots { position: absolute; left: 50%; bottom: 9px; display: flex; gap: 6px; transform: translateX(-50%); }
.ad-dots button { width: 8px; height: 8px; padding: 0; border: 1px solid white; border-radius: 50%; background: rgba(255,255,255,.45); }
.ad-dots button.active { background: var(--orange); }
.ad-slot-compact .ad-banner img { aspect-ratio: 1.2; }
.detail-sidebar > .ad-slot { margin-bottom: 18px; }

.artwork-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 22px; }
.artwork-card { overflow: hidden; border: 1px solid var(--line); border-radius: var(--radius); background: white; transition: .22s ease; }
.artwork-card:hover { transform: translateY(-4px); box-shadow: var(--shadow); }
.artwork-image { overflow: hidden; position: relative; aspect-ratio: .92; display: block; background: #e9e7e3; }
.artwork-image img { width: 100%; height: 100%; object-fit: cover; transition: transform .5s ease; }
.artwork-card:hover .artwork-image img { transform: scale(1.035); }
.artwork-body { padding: 20px; }
.artist-name { color: var(--orange-dark); font-size: .76rem; font-weight: 800; letter-spacing: .08em; text-transform: uppercase; }
.artwork-body h3 { margin: 7px 0 15px; font-size: 1.25rem; }
.artwork-meta { display: flex; justify-content: space-between; gap: 12px; margin-bottom: 14px; color: var(--muted); font-size: .8rem; }
.artwork-meta strong { color: var(--ink); }
.art-hero { background: linear-gradient(120deg, #15110f, #402518 70%, #111); }
.art-listing-section { padding-top: 0; }
.art-filter-grid { grid-template-columns: 2fr 1fr 1fr auto; }
.art-manifesto { display: grid; grid-template-columns: 1fr 1fr; gap: 50px; align-items: center; }
.art-manifesto h2 { font-size: clamp(2rem, 4vw, 3.5rem); }
.art-manifesto p { color: #c7c9cd; font-size: 1.05rem; }
.art-detail-gallery figure { position: relative; }
.art-detail-gallery figcaption { position: absolute; right: 10px; bottom: 10px; padding: 5px 8px; border-radius: 6px; color: white; background: rgba(0,0,0,.68); font-size: .7rem; }
.artist-profile { margin-top: 42px; padding: 30px; border-left: 4px solid var(--orange); background: var(--surface); }
.art-contact-card { border-top: 4px solid var(--orange); }
.home-art-grid { display: grid; grid-template-columns: .65fr 1.35fr; gap: 45px; align-items: center; }
.home-art-intro h2 { font-size: clamp(2.2rem, 4vw, 3.8rem); }
.home-art-intro p { color: var(--muted); font-size: 1.02rem; }
.home-artworks { display: grid; grid-template-columns: repeat(2, 1fr); gap: 18px; }
.home-artworks .artwork-card:nth-child(n+3) { display: none; }
.art-placeholder { min-height: 430px; grid-column: 1 / -1; display: flex; justify-content: flex-end; align-items: flex-start; flex-direction: column; padding: 42px; border-radius: var(--radius); color: white; background: linear-gradient(145deg, rgba(17,18,22,.25), rgba(17,18,22,.92)), url('/images/innerhayti-services.jpeg') center/cover; }
.art-placeholder span { color: #ffb27d; font-weight: 800; letter-spacing: .15em; text-transform: uppercase; }
.art-placeholder strong { max-width: 480px; margin: 8px 0 14px; font-family: "Manrope", sans-serif; font-size: 2rem; }
.art-placeholder a { color: #ffb27d; font-weight: 800; }

.stats-band { color: white; background: var(--ink); }
.stats-grid { display: grid; grid-template-columns: repeat(4, 1fr); }
.stat-item { padding: 38px; border-right: 1px solid #2c2e33; text-align: center; }
.stat-item:last-child { border-right: 0; }
.stat-item strong { display: block; color: var(--orange); font-family: "Manrope", sans-serif; font-size: 2.4rem; }
.stat-item span { color: #c4c7cc; font-size: .84rem; }

.services-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 18px; }
.service-card { padding: 30px; border: 1px solid var(--line); border-radius: var(--radius); background: white; }
.service-card .type-icon { margin-bottom: 20px; }
.service-card p { color: var(--muted); }
.center-action { margin-top: 30px; text-align: center; }
.service-cta { margin-top: 28px; padding: 34px; display: flex; align-items: center; justify-content: space-between; gap: 25px; border-radius: var(--radius); color: white; background: var(--orange); }
.service-cta h2 { margin: 0; }

.page-hero { padding: 76px 0 68px; color: white; background: linear-gradient(125deg, #101114, #24252a); }
.page-hero .eyebrow { color: #ffb98e; }
.page-hero h1 { max-width: 840px; font-size: clamp(2.25rem, 5vw, 4.2rem); }
.page-hero p { max-width: 700px; color: #c8cbd0; font-size: 1.05rem; }
.breadcrumb { display: flex; flex-wrap: wrap; gap: 8px; margin-bottom: 18px; color: #b9bcc2; font-size: .8rem; }
.breadcrumb a:hover { color: var(--orange); }

.filter-panel { margin-top: -34px; position: relative; z-index: 3; padding: 22px; border: 1px solid var(--line); border-radius: var(--radius); background: white; box-shadow: var(--shadow); }
.listings-section { padding-top: 0; }
.clear-filters { display: inline-block; margin-top: 12px; color: var(--orange-dark); font-size: .82rem; font-weight: 800; }
.filter-grid { display: grid; grid-template-columns: 2fr repeat(3, 1fr) auto; gap: 12px; }
.form-control, .form-select, .form-textarea { width: 100%; border: 1px solid #d8dbe0; border-radius: 10px; outline: 0; background: white; transition: .2s; }
.form-control, .form-select { min-height: 48px; padding: 0 13px; }
.form-textarea { min-height: 130px; padding: 13px; resize: vertical; }
.form-control:focus, .form-select:focus, .form-textarea:focus { border-color: var(--orange); box-shadow: 0 0 0 3px rgba(245, 109, 19, .12); }
.form-group { margin-bottom: 18px; }
.form-group label { display: block; margin-bottom: 7px; font-size: .84rem; font-weight: 800; }
.form-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; }
.form-help { margin-top: 5px; color: var(--muted); font-size: .75rem; }
.results-toolbar { display: flex; justify-content: space-between; gap: 20px; margin: 30px 0 22px; }
.results-toolbar strong { font-family: "Manrope", sans-serif; }
.empty-state { padding: 70px 30px; border: 1px dashed #ccd0d6; border-radius: var(--radius); text-align: center; }
.empty-state h2 { font-size: 1.5rem; }
.empty-state p { color: var(--muted); }
.pagination { display: flex; align-items: center; justify-content: center; gap: 20px; margin-top: 36px; }
.pagination a, .pagination .disabled { padding: 9px 14px; border: 1px solid var(--line); border-radius: 9px; font-size: .82rem; font-weight: 700; }
.pagination a:hover { color: white; border-color: var(--orange); background: var(--orange); }
.pagination .disabled { color: #aaa; }

.detail-layout { display: grid; grid-template-columns: minmax(0, 1.55fr) minmax(310px, .65fr); gap: 34px; align-items: start; }
.detail-gallery { display: grid; grid-template-columns: repeat(2, 1fr); gap: 10px; }
.detail-gallery figure { overflow: hidden; margin: 0; border-radius: 14px; background: #eee; }
.detail-gallery figure:first-child { grid-column: 1 / -1; aspect-ratio: 1.9; }
.detail-gallery figure:not(:first-child) { aspect-ratio: 1.4; }
.detail-gallery img { width: 100%; height: 100%; object-fit: cover; }
.detail-main { margin-top: 28px; }
.detail-badges { display: flex; flex-wrap: wrap; gap: 8px; margin-bottom: 15px; }
.badge { display: inline-flex; padding: 6px 10px; border-radius: 999px; color: #383a40; background: #eceef1; font-size: .72rem; font-weight: 800; }
.badge.orange { color: var(--orange-dark); background: var(--orange-soft); }
.detail-main h1 { font-size: clamp(2rem, 4vw, 3.3rem); }
.detail-summary { display: flex; flex-wrap: wrap; gap: 20px; margin: 18px 0 25px; color: var(--muted); font-size: .86rem; }
.detail-description { color: #363940; font-size: 1.02rem; white-space: pre-line; }
.detail-sidebar { position: sticky; top: 110px; }
.listing-layout-gallery .detail-layout { grid-template-columns: 1fr; }
.listing-layout-gallery .detail-gallery figure:first-child { aspect-ratio: 2.25; }
.listing-layout-gallery .detail-sidebar { position: static; display: grid; grid-template-columns: repeat(2, 1fr); gap: 18px; }
.listing-layout-gallery .detail-sidebar .ad-slot { grid-column: 1 / -1; }
.listing-layout-compact .detail-layout { grid-template-columns: minmax(0, 1.05fr) minmax(330px, .95fr); }
.listing-layout-compact .detail-gallery figure:not(:first-child) { display: none; }
.listing-layout-compact .detail-gallery figure:first-child { aspect-ratio: 1.45; }
.listing-layout-compact .detail-main h1 { font-size: clamp(1.8rem, 3vw, 2.5rem); }
.sidebar-card { margin-bottom: 18px; padding: 24px; border: 1px solid var(--line); border-radius: var(--radius); background: white; box-shadow: 0 12px 35px rgba(17, 18, 22, .06); }
.sidebar-price { margin-bottom: 18px; color: var(--orange-dark); font-family: "Manrope", sans-serif; font-size: 2rem; font-weight: 800; }
.sidebar-card h3 { font-size: 1.12rem; }
.contact-list { margin: 16px 0; padding: 0; list-style: none; }
.contact-list li { padding: 9px 0; border-bottom: 1px solid var(--line); }
.contact-list small { display: block; color: var(--muted); }
.action-stack { display: grid; gap: 10px; }
.detail-actions { display: flex; flex-wrap: wrap; gap: 10px; margin: 22px 0; }
.detail-actions form { margin: 0; }
.specific-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 1px; overflow: hidden; margin-top: 22px; border: 1px solid var(--line); border-radius: 14px; background: var(--line); }
.specific-item { padding: 15px 17px; background: white; }
.specific-item small { display: block; margin-bottom: 3px; color: var(--muted); }
.specific-item strong { word-break: break-word; }

.reviews-section { margin-top: 52px; padding-top: 44px; border-top: 1px solid var(--line); }
.reviews-layout { display: grid; grid-template-columns: .8fr 1.2fr; gap: 34px; }
.rating-summary { padding: 28px; border-radius: var(--radius); background: var(--surface); text-align: center; }
.rating-summary strong { display: block; font-family: "Manrope", sans-serif; font-size: 3.2rem; }
.stars { color: #ff9c3d; letter-spacing: 2px; }
.comment-list { display: grid; gap: 14px; margin-top: 24px; }
.comment { padding: 20px; border: 1px solid var(--line); border-radius: 14px; }
.comment-head { display: flex; justify-content: space-between; gap: 15px; margin-bottom: 8px; }
.comment-head small { color: var(--muted); }
.comment p { color: #43464d; white-space: pre-line; }
.empty-comment { padding: 18px; border-radius: 12px; color: var(--muted); background: var(--surface); }
.review-form { padding: 28px; border: 1px solid var(--line); border-radius: var(--radius); }
.rating-select { display: flex; flex-direction: row-reverse; justify-content: flex-end; gap: 4px; }
.rating-select input { position: absolute; opacity: 0; }
.rating-select label { color: #ccd0d5; font-size: 1.9rem; cursor: pointer; }
.rating-select input:checked ~ label, .rating-select label:hover, .rating-select label:hover ~ label { color: #ff9c3d; }

.article-layout { display: grid; grid-template-columns: minmax(0, 1fr) 320px; gap: 44px; align-items: start; }
.article-header { max-width: 860px; margin-bottom: 30px; }
.article-header h1 { font-size: clamp(2.3rem, 5vw, 4.5rem); }
.article-lead { color: var(--muted); font-size: 1.15rem; }
.article-cover { overflow: hidden; margin-bottom: 34px; border-radius: 20px; aspect-ratio: 1.9; }
.article-cover img { width: 100%; height: 100%; object-fit: cover; }
.article-content { color: #30333a; font-size: 1.06rem; }
.article-content h2, .article-content h3 { margin-top: 1.7em; }
.article-content p { margin-bottom: 1.25em; }
.article-content img { border-radius: 14px; }
.article-sidebar { position: sticky; top: 110px; }
.article-detail-section { padding-top: 64px; }
.dark-breadcrumb { color: var(--muted); }
.article-search { display: grid; grid-template-columns: minmax(0, 2fr) minmax(180px, .8fr) auto; gap: 10px; margin-bottom: 20px; }
.article-grid-wide { grid-template-columns: repeat(3, 1fr); }
.article-comment-form { margin-top: 28px; }
.mini-article-list { display: grid; }
.mini-article-list a { padding: 14px 0; border-bottom: 1px solid var(--line); }
.mini-article-list a:last-child { border-bottom: 0; }
.mini-article-list small, .mini-article-list strong { display: block; }
.mini-article-list small { color: var(--muted); }
.safety-card ul { padding-left: 19px; color: var(--muted); font-size: .85rem; }
.safety-card a { color: var(--orange-dark); font-weight: 800; }

.content-card { padding: 34px; border: 1px solid var(--line); border-radius: var(--radius); background: white; }
.content-grid { display: grid; grid-template-columns: 1.15fr .85fr; gap: 30px; }
.contact-info { padding: 34px; border-radius: var(--radius); color: white; background: var(--ink); }
.contact-info a { color: #ffd0b2; }
.contact-info hr { margin: 25px 0; border: 0; border-top: 1px solid #35373c; }
.prose { max-width: 800px; color: #34373d; }
.prose h2 { margin-top: 2rem; font-size: 1.6rem; }
.prose ul { padding-left: 20px; }

.newsletter-band { padding: 58px 0; color: white; background: var(--orange); }
.newsletter-grid { display: grid; grid-template-columns: 1fr 1.05fr; gap: 50px; align-items: center; }
.newsletter-grid h2 { font-size: clamp(1.7rem, 3vw, 2.5rem); }
.newsletter-grid p { color: #fff0e6; }
.newsletter-fields { display: grid; grid-template-columns: 1fr 1.35fr auto; gap: 8px; }
.newsletter-fields input { min-width: 0; height: 48px; padding: 0 13px; border: 1px solid rgba(255, 255, 255, .35); border-radius: 10px; outline: 0; color: white; background: rgba(255, 255, 255, .12); }
.newsletter-fields input::placeholder { color: #ffe2cf; }
.newsletter-options { display: flex; flex-wrap: wrap; gap: 18px; margin-top: 12px; color: #fff2ea; font-size: .78rem; }
.newsletter-options input { accent-color: #111; }
.site-footer { color: #c9cbd0; background: #0b0b0d; }
.footer-grid { display: grid; grid-template-columns: 1.7fr repeat(3, 1fr); gap: 55px; padding: 68px 0 50px; }
.footer-grid h3 { color: white; font-size: .95rem; }
.footer-grid > div:not(.footer-brand) a { display: block; padding: 5px 0; font-size: .84rem; }
.footer-grid a:hover { color: var(--orange); }
.footer-brand img { width: 160px; height: 76px; object-fit: contain; margin-bottom: 16px; background: white; border-radius: 10px; }
.footer-brand p { max-width: 400px; }
.social-links { display: flex; gap: 8px; margin-top: 18px; }
.social-links a { width: 34px; height: 34px; display: grid; place-items: center; border: 1px solid #33353a; border-radius: 50%; color: white; font-size: .75rem; font-weight: 800; }
.footer-bottom { min-height: 66px; display: flex; align-items: center; justify-content: space-between; gap: 20px; border-top: 1px solid #292b2f; font-size: .78rem; }
.footer-bottom div { display: flex; gap: 20px; }

@media (max-width: 1050px) {
    .mobile-menu-button { display: block; margin-left: auto; }
    .main-nav { position: absolute; top: 82px; left: 20px; right: 20px; display: none; align-items: stretch; flex-direction: column; padding: 15px; border: 1px solid var(--line); border-radius: 15px; background: white; box-shadow: var(--shadow); }
    .main-nav.open { display: flex; }
    .main-nav > a, .nav-dropdown > button { width: 100%; text-align: left; }
    .dropdown-menu, .dropdown-menu.compact { position: static; width: 100%; display: none; visibility: visible; transform: none; opacity: 1; box-shadow: none; }
    .nav-dropdown.open .dropdown-menu { display: block; transform: none; }
    .nav-dropdown:hover .dropdown-menu { display: none; }
    .nav-dropdown.open:hover .dropdown-menu { display: block; }
    .type-grid { grid-template-columns: repeat(3, 1fr); }
    .article-grid, .artwork-grid { grid-template-columns: repeat(2, 1fr); }
    .filter-grid { grid-template-columns: repeat(2, 1fr); }
    .filter-grid .btn { grid-column: span 2; }
}

@media (max-width: 760px) {
    .container { width: min(100% - 28px, 1180px); }
    .topbar { display: none; }
    .header-inner { min-height: 70px; }
    .brand, .brand img { width: 112px; height: 48px; flex-basis: 112px; }
    .main-nav { top: 70px; }
    .header-actions { display: none; }
    .section { padding: 58px 0; }
    .section-heading { align-items: start; flex-direction: column; }
    .hero { min-height: 610px; }
    .hero-media { inset: 0; }
    .ad-banner img { aspect-ratio: 1.45; }
    .hero::after { background: rgba(10, 10, 12, .85); }
    .hero-content { padding: 75px 0; }
    .hero h1 { font-size: 2.8rem; }
    .hero-search { grid-template-columns: 1fr; }
    .type-grid, .listing-grid, .article-grid, .article-grid-wide, .artwork-grid, .services-grid, .stats-grid, .footer-grid, .newsletter-grid, .content-grid, .detail-layout, .article-layout, .reviews-layout, .home-art-grid, .art-manifesto { grid-template-columns: 1fr; }
    .type-grid { grid-template-columns: repeat(2, 1fr); }
    .listing-grid { gap: 16px; }
    .stat-item { border-right: 0; border-bottom: 1px solid #2c2e33; }
    .newsletter-fields, .form-grid, .filter-grid, .specific-grid { grid-template-columns: 1fr; }
    .article-search { grid-template-columns: 1fr; }
    .filter-grid .btn { grid-column: auto; }
    .newsletter-fields .btn { width: 100%; }
    .footer-grid { gap: 28px; }
    .footer-bottom { align-items: flex-start; flex-direction: column; padding: 22px 0; }
    .detail-sidebar, .article-sidebar { position: static; }
    .detail-gallery { grid-template-columns: 1fr; }
    .detail-gallery figure:first-child { grid-column: auto; }
    .page-hero { padding: 55px 0; }
    .service-cta { align-items: flex-start; flex-direction: column; }
    .home-artworks { grid-template-columns: 1fr; }
    .art-filter-grid { grid-template-columns: 1fr; }
}

@media (max-width: 480px) {
    .type-grid { grid-template-columns: 1fr; }
    .hero-actions, .detail-actions { display: grid; }
    .hero-actions .btn, .detail-actions .btn { width: 100%; }
}
