/*
Theme Name: Archiprints Noir Studio Editorial
Theme URI: https://archiprints.com.tr
Author: OpenAI for Archiprints
Description: A premium black/gray/white/red editorial-studio WordPress theme for Archiprints. Keeps full Customizer control, TR/EN homepage text, light/dark mode, platform cards, brand typography controls, and mobile-first layouts with a refreshed visual skin.
Version: 4.8.0
Requires at least: 6.0
Tested up to: 6.6
Requires PHP: 8.0
License: GPLv2 or later
License URI: https://www.gnu.org/licenses/gpl-2.0.html
Text Domain: archiprints-noir
Tags: custom-logo, custom-menu, featured-images, translation-ready, blog, portfolio, grid-layout
*/

:root {
  --ap-accent: #d71920;
  --ap-accent-2: #ff333b;
  --ap-radius-xl: 34px;
  --ap-radius-lg: 24px;
  --ap-radius-md: 16px;
  --ap-radius-sm: 10px;
  --ap-max: 1240px;
  --ap-font: Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  --ap-display: "Inter Tight", Inter, ui-sans-serif, system-ui, sans-serif;
  --ap-nav-font: var(--ap-font);
  --ap-platform-title-font: var(--ap-display);
  --ap-platform-text-font: var(--ap-font);
  --ap-platform-title-color: #ffffff;
  --ap-platform-text-color: #d7d7dc;
  --ap-platform-overlay: rgba(0,0,0,.58);
  --ap-body-size: 16px;
  --ap-title-max: 78px;
  --ap-header-min-height: 76px;
  --ap-logo-max-height: 42px;
  --ap-brand-mark-size: 38px;
  --ap-brand-name-size: 15px;
  --ap-brand-letter-spacing: .12em;
  --ap-button-radius: 999px;
  --ap-card-radius-custom: var(--ap-radius-lg);
  --ap-mono: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", monospace;
}

html[data-theme="dark"],
body.ap-theme-dark {
  --ap-bg: #07080a;
  --ap-bg-2: #0d0f13;
  --ap-panel: #11141a;
  --ap-card: #151922;
  --ap-card-2: #0f1218;
  --ap-text: #f5f6f8;
  --ap-muted: #a5abb7;
  --ap-soft: #757d8c;
  --ap-line: rgba(255,255,255,.10);
  --ap-line-strong: rgba(255,255,255,.18);
  --ap-shadow: 0 30px 100px rgba(0,0,0,.45);
  --ap-glow: 0 0 0 1px rgba(215,25,32,.25), 0 18px 90px rgba(215,25,32,.16);
  --ap-gradient: radial-gradient(circle at 20% 0%, rgba(215,25,32,.18), transparent 32%), radial-gradient(circle at 86% 20%, rgba(255,255,255,.08), transparent 28%), linear-gradient(180deg, #090a0d 0%, #07080a 100%);
}

html[data-theme="light"],
body.ap-theme-light {
  --ap-bg: #f7f7f8;
  --ap-bg-2: #ffffff;
  --ap-panel: #ffffff;
  --ap-card: #ffffff;
  --ap-card-2: #f0f1f3;
  --ap-text: #111217;
  --ap-muted: #5e6470;
  --ap-soft: #858b95;
  --ap-line: rgba(17,18,23,.11);
  --ap-line-strong: rgba(17,18,23,.18);
  --ap-shadow: 0 30px 100px rgba(15,17,22,.10);
  --ap-glow: 0 0 0 1px rgba(215,25,32,.18), 0 18px 80px rgba(215,25,32,.10);
  --ap-gradient: radial-gradient(circle at 20% 0%, rgba(215,25,32,.09), transparent 34%), radial-gradient(circle at 86% 20%, rgba(0,0,0,.05), transparent 28%), linear-gradient(180deg, #ffffff 0%, #f7f7f8 100%);
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
  margin: 0;
  min-width: 320px;
  background: var(--ap-bg);
  color: var(--ap-text);
  font-family: var(--ap-font);
  font-size: var(--ap-body-size, 16px);
  line-height: 1.6;
  text-rendering: geometricPrecision;
  -webkit-font-smoothing: antialiased;
}
body.ap-lock { overflow: hidden; }
a { color: inherit; text-decoration: none; }
a:hover { color: var(--ap-accent); }
img { max-width: 100%; height: auto; display: block; }
button, input, textarea, select { font: inherit; }
::selection { background: var(--ap-accent); color: #fff; }

.ap-shell { min-height: 100vh; overflow: clip; background: var(--ap-gradient); }
.ap-container { width: min(var(--ap-max), calc(100% - 40px)); margin-inline: auto; }
.ap-section { padding: clamp(58px, 8vw, 116px) 0; position: relative; }
.ap-section-tight { padding: clamp(38px, 6vw, 80px) 0; }
.ap-eyebrow {
  display: inline-flex; align-items: center; gap: 10px;
  margin: 0 0 14px; color: var(--ap-accent); text-transform: uppercase;
  letter-spacing: .18em; font-size: 12px; font-weight: 800;
}
.ap-eyebrow::before { content: ""; width: 28px; height: 2px; background: currentColor; }
.ap-title {
  margin: 0; font-family: var(--ap-display); font-size: clamp(36px, 5vw, var(--ap-title-max, 78px));
  line-height: .96; letter-spacing: -.06em; font-weight: 850;
}
.ap-title .ap-red { color: var(--ap-accent); }
.ap-lead { margin: 18px 0 0; color: var(--ap-muted); font-size: clamp(16px, 1.65vw, 20px); max-width: 680px; }
.ap-kicker { color: var(--ap-soft); font-size: 14px; letter-spacing: .02em; }
.ap-muted { color: var(--ap-muted); }
.ap-red { color: var(--ap-accent); }

/* Header */
.ap-site-header {
  position: sticky; top: 0; z-index: 80;
  border-bottom: 1px solid var(--ap-line);
  background: color-mix(in srgb, var(--ap-bg) 82%, transparent);
  backdrop-filter: blur(18px);
}
.ap-header-inner { min-height: var(--ap-header-min-height, 76px); display: flex; align-items: center; justify-content: space-between; gap: 18px; }
.ap-brand { display: inline-flex; align-items: center; gap: 12px; min-width: 0; }
.ap-brand-logo { max-height: var(--ap-logo-max-height, 42px); width: auto; object-fit: contain; }
.ap-brand img { width: auto; }
.ap-brand-mark {
  width: var(--ap-brand-mark-size, 38px); height: var(--ap-brand-mark-size, 38px); display: grid; place-items: center;
  border: 1px solid var(--ap-line-strong); border-radius: 12px;
  background: linear-gradient(145deg, var(--ap-card), var(--ap-card-2));
  box-shadow: inset 4px 0 0 var(--ap-accent);
  font-weight: 900; letter-spacing: -.05em;
}
.ap-brand-text { display: grid; line-height: 1; }
.ap-brand-name { font-family: var(--ap-display); text-transform: uppercase; letter-spacing: var(--ap-brand-letter-spacing, .12em); font-weight: 900; font-size: var(--ap-brand-name-size, 15px); }
.ap-brand-tag { margin-top: 6px; color: var(--ap-soft); font-size: 11px; letter-spacing: .15em; text-transform: uppercase; }

.ap-brand-mark img { width: 76%; height: 76%; object-fit: contain; }
.ap-brand-mode-logo_only .ap-brand-logo { max-width: min(260px, 45vw); }
.ap-brand-mode-logo_text .ap-brand-logo { max-width: min(180px, 35vw); }
.ap-brand-mark-style-circle .ap-brand-mark { border-radius: 999px; box-shadow: inset 0 0 0 2px var(--ap-accent); }
.ap-brand-mark-style-plain .ap-brand-mark { border: 0; border-radius: 0; background: transparent; box-shadow: none; }
.ap-brand-mark-style-slash .ap-brand-mark { box-shadow: none; overflow: hidden; }
.ap-brand-mark-style-slash .ap-brand-mark::before { content: ""; position: absolute; inset: 0 auto 0 0; width: 5px; background: var(--ap-accent); }
.ap-brand-mark { position: relative; flex: 0 0 auto; }
.ap-header-style-solid .ap-site-header { background: var(--ap-bg); backdrop-filter: none; }
.ap-header-style-flat .ap-site-header { background: transparent; backdrop-filter: none; border-bottom-color: transparent; }
.ap-nav-style-underline .ap-menu a { background: transparent !important; border-radius: 0; position: relative; }
.ap-nav-style-underline .ap-menu a::after { content: ""; position: absolute; left: 12px; right: 12px; bottom: 4px; height: 2px; background: var(--ap-accent); transform: scaleX(0); transform-origin: left; transition: transform .22s ease; }
.ap-nav-style-underline .ap-menu a:hover::after,
.ap-nav-style-underline .ap-menu .current-menu-item > a::after,
.ap-nav-style-underline .ap-menu .current_page_item > a::after { transform: scaleX(1); }
.ap-nav-style-minimal .ap-menu a { background: transparent !important; border-radius: 0; padding-inline: 10px; }
.ap-nav-style-minimal .ap-menu a:hover,
.ap-nav-style-minimal .ap-menu .current-menu-item > a,
.ap-nav-style-minimal .ap-menu .current_page_item > a { color: var(--ap-accent); }
.ap-nav-wrap { display: flex; align-items: center; gap: 12px; }
.ap-menu { display: flex; align-items: center; gap: 4px; list-style: none; margin: 0; padding: 0; }
.ap-menu a {
  display: inline-flex; padding: 10px 12px; border-radius: 999px;
  color: var(--ap-muted); font-family: var(--ap-nav-font); font-size: 14px; font-weight: 700;
  transition: color .2s ease, background .2s ease, transform .2s ease;
}
.ap-menu a:hover, .ap-menu .current-menu-item > a, .ap-menu .current_page_item > a {
  color: var(--ap-text); background: var(--ap-card);
}
.ap-header-tools { display: flex; align-items: center; gap: 8px; }
.ap-tool-btn, .ap-mobile-toggle, .ap-lang a, .ap-cta {
  min-height: 40px; border-radius: 999px; border: 1px solid var(--ap-line-strong);
  background: var(--ap-card); color: var(--ap-text); display: inline-flex; align-items: center; justify-content: center;
  gap: 8px; padding: 0 14px; font-weight: 800; font-size: 13px; cursor: pointer;
  transition: transform .2s ease, border-color .2s ease, background .2s ease, color .2s ease;
}
.ap-tool-btn:hover, .ap-mobile-toggle:hover, .ap-lang a:hover { transform: translateY(-1px); border-color: color-mix(in srgb, var(--ap-accent) 60%, var(--ap-line-strong)); }
.ap-tool-btn { width: 42px; padding: 0; }
.ap-cta { background: var(--ap-accent); color: #fff; border-color: var(--ap-accent); box-shadow: 0 12px 34px rgba(215,25,32,.26); }
.ap-cta:hover { color: #fff; transform: translateY(-1px); background: var(--ap-accent-2); }
.ap-lang { display: flex; gap: 4px; }
.ap-lang a { padding: 0 10px; min-width: 40px; }
.ap-lang .current-lang a { background: var(--ap-accent); color: #fff; border-color: var(--ap-accent); }
.ap-lang .missing-lang a { opacity: .65; }
.ap-mobile-toggle { display: none; width: 44px; padding: 0; }
.ap-mobile-toggle span, .ap-mobile-toggle::before, .ap-mobile-toggle::after { content: ""; width: 18px; height: 2px; background: currentColor; display: block; border-radius: 999px; position: absolute; transition: transform .2s ease, opacity .2s ease; }
.ap-mobile-toggle { position: relative; }
.ap-mobile-toggle::before { transform: translateY(-6px); }
.ap-mobile-toggle::after { transform: translateY(6px); }
.ap-mobile-toggle[aria-expanded="true"] span { opacity: 0; }
.ap-mobile-toggle[aria-expanded="true"]::before { transform: rotate(45deg); }
.ap-mobile-toggle[aria-expanded="true"]::after { transform: rotate(-45deg); }

/* Buttons */
.ap-buttons { display: flex; align-items: center; flex-wrap: wrap; gap: 12px; margin-top: 28px; }
.ap-btn {
  display: inline-flex; align-items: center; justify-content: center; gap: 9px;
  min-height: 48px; padding: 0 20px; border-radius: var(--ap-button-radius, 999px);
  border: 1px solid var(--ap-line-strong); background: var(--ap-card); color: var(--ap-text);
  font-size: 14px; font-weight: 900; letter-spacing: -.01em;
  transition: transform .2s ease, background .2s ease, border-color .2s ease, box-shadow .2s ease;
}
.ap-btn:hover { transform: translateY(-2px); border-color: var(--ap-accent); color: var(--ap-text); }
.ap-btn-primary { color: #fff; background: var(--ap-accent); border-color: var(--ap-accent); box-shadow: 0 20px 56px rgba(215,25,32,.24); }
.ap-btn-primary:hover { color: #fff; background: var(--ap-accent-2); }
.ap-btn-ghost { background: transparent; }

/* Hero */
.ap-hero { padding: clamp(44px, 7vw, 96px) 0 clamp(46px, 7vw, 90px); }
.ap-hero-grid { display: grid; grid-template-columns: minmax(0, 1.02fr) minmax(380px, .98fr); gap: clamp(32px, 5vw, 72px); align-items: center; }
.ap-hero-panel {
  position: relative; min-height: 520px; border: 1px solid var(--ap-line); border-radius: var(--ap-radius-xl);
  background: linear-gradient(145deg, color-mix(in srgb, var(--ap-card) 92%, transparent), color-mix(in srgb, var(--ap-card-2) 96%, transparent));
  box-shadow: var(--ap-shadow); overflow: hidden; isolation: isolate;
}
.ap-hero-panel::before { content: ""; position: absolute; inset: 0; background: radial-gradient(circle at 16% 16%, rgba(215,25,32,.28), transparent 23%), linear-gradient(135deg, transparent 0 58%, rgba(215,25,32,.13) 58% 59%, transparent 59%); z-index: -1; }
.ap-showcase { position: absolute; inset: 28px; display: grid; grid-template-columns: .88fr .72fr; grid-template-rows: 1fr 1fr; gap: 18px; }
.ap-art-card {
  border: 1px solid var(--ap-line); border-radius: 24px; background: color-mix(in srgb, var(--ap-bg) 18%, var(--ap-card) 82%);
  padding: 20px; box-shadow: 0 20px 60px rgba(0,0,0,.18); position: relative; overflow: hidden;
}
.ap-art-card.large { grid-row: span 2; display: flex; flex-direction: column; justify-content: flex-end; min-height: 430px; }
.ap-art-card::after { content: ""; position: absolute; inset: auto -20% -35% -20%; height: 55%; background: radial-gradient(ellipse, rgba(215,25,32,.22), transparent 65%); }
.ap-bookmark {
  position: absolute; inset: 26px 34px auto; height: 72%; border-radius: 28px 28px 12px 12px;
  background: linear-gradient(180deg, var(--ap-text), color-mix(in srgb, var(--ap-text) 70%, var(--ap-bg)));
  clip-path: polygon(0 0,100% 0,100% 88%,50% 100%,0 88%);
  box-shadow: 18px 22px 0 rgba(215,25,32,.18), 0 26px 80px rgba(0,0,0,.22);
}
.ap-bookmark::before { content: ""; position: absolute; inset: 16px; border: 1px solid color-mix(in srgb, var(--ap-bg) 55%, transparent); border-radius: 20px; background: repeating-linear-gradient(135deg, transparent 0 12px, rgba(215,25,32,.32) 12px 14px); }
.ap-bookmark::after { content: "ARCHIPRINTS"; position: absolute; left: 50%; bottom: 38px; transform: translateX(-50%) rotate(-90deg); color: color-mix(in srgb, var(--ap-bg) 80%, transparent); font-size: 11px; letter-spacing: .24em; font-weight: 900; }
.ap-art-label { position: relative; z-index: 2; margin-top: auto; }
.ap-art-label strong { display: block; font-family: var(--ap-display); font-size: 28px; letter-spacing: -.06em; line-height: 1.0; }
.ap-art-label span { color: var(--ap-muted); font-size: 13px; }
.ap-mini-sculpture { height: 96px; border-radius: 24px; margin-top: 26px; background: radial-gradient(circle at 50% 30%, var(--ap-text), transparent 12%), repeating-radial-gradient(circle at 50% 55%, transparent 0 11px, color-mix(in srgb, var(--ap-text) 64%, transparent) 12px 14px), linear-gradient(180deg, transparent, rgba(215,25,32,.16)); opacity: .95; }
.ap-art-media {
  position: absolute; inset: 20px 20px 104px; z-index: 1;
  border: 1px solid var(--ap-line); border-radius: 20px; overflow: hidden;
  background: linear-gradient(135deg, var(--ap-card-2), var(--ap-card));
}
.ap-art-card.large .ap-art-media { inset: 24px 24px 118px; border-radius: 24px; }
.ap-art-card:not(.large) .ap-art-media { inset: 18px 18px 88px; border-radius: 18px; }
.ap-art-media img, .ap-art-image { width: 100%; height: 100%; object-fit: cover; }
.ap-art-media .ap-placeholder { height: 100%; border-radius: inherit; }
.ap-art-card.has-custom-image .ap-bookmark,
.ap-art-card.has-custom-image .ap-mini-sculpture { display: none; }
.ap-art-card.has-custom-image::after { opacity: .45; pointer-events: none; }
.ap-art-label { position: absolute; z-index: 3; left: 20px; right: 20px; bottom: 18px; margin-top: 0; }
.ap-art-card.large .ap-art-label { left: 24px; right: 24px; bottom: 24px; }
.ap-art-card:not(.large) .ap-art-label strong { font-size: 22px; }
.ap-placeholder.ap-placeholder-image-wrap { padding: 0; background: var(--ap-card-2); }
.ap-placeholder-image { width: 100%; height: 100%; object-fit: cover; }
.ap-placeholder.has-image .ap-placeholder-inner { display: none; }

.ap-stats { display: grid; grid-template-columns: repeat(3, 1fr); gap: 12px; margin-top: 32px; }
.ap-stat { border-left: 2px solid var(--ap-accent); padding: 8px 0 8px 14px; }
.ap-stat strong { display: block; font-size: 22px; line-height: 1; font-weight: 900; letter-spacing: -.04em; }
.ap-stat span { color: var(--ap-muted); font-size: 12px; text-transform: uppercase; letter-spacing: .08em; }

/* Cards and gallery */
.ap-section-head { display: flex; align-items: end; justify-content: space-between; gap: 24px; margin-bottom: 26px; }
.ap-section-head .ap-lead { margin-top: 10px; max-width: 620px; }
.ap-filterbar { display: flex; gap: 8px; flex-wrap: wrap; }
.ap-chip {
  display: inline-flex; align-items: center; justify-content: center; min-height: 36px; padding: 0 13px;
  border-radius: 999px; border: 1px solid var(--ap-line); color: var(--ap-muted); background: var(--ap-card); font-size: 13px; font-weight: 800;
}
.ap-chip.is-active, .ap-chip:hover { color: #fff; background: var(--ap-accent); border-color: var(--ap-accent); }
.ap-gallery { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 18px; }
.ap-gallery.ap-gallery-collections { grid-template-columns: repeat(2, minmax(0, 1fr)); }
.ap-card {
  position: relative; min-width: 0; border: 1px solid var(--ap-line); border-radius: var(--ap-card-radius-custom, var(--ap-radius-lg));
  background: linear-gradient(180deg, var(--ap-card), var(--ap-card-2)); overflow: hidden; box-shadow: 0 18px 70px rgba(0,0,0,.08);
  transition: transform .24s ease, border-color .24s ease, box-shadow .24s ease;
}
.ap-card:hover { transform: translateY(-5px); border-color: color-mix(in srgb, var(--ap-accent) 55%, var(--ap-line)); box-shadow: var(--ap-glow); }
.ap-card-media { aspect-ratio: 16/11; background: var(--ap-card-2); border-bottom: 1px solid var(--ap-line); position: relative; overflow: hidden; }
.ap-card-media img { width: 100%; height: 100%; object-fit: cover; }
.ap-card-media::before { content: ""; position: absolute; inset: 0; background: radial-gradient(circle at 80% 12%, rgba(215,25,32,.24), transparent 24%), linear-gradient(135deg, transparent 0 48%, rgba(255,255,255,.06) 48% 49%, transparent 49%); pointer-events: none; }
.ap-placeholder { width: 100%; height: 100%; display: grid; place-items: center; background: linear-gradient(135deg, var(--ap-card), var(--ap-card-2)); }
.ap-placeholder-inner { width: 54%; aspect-ratio: 1; border-radius: 28px; border: 1px solid var(--ap-line-strong); position: relative; background: repeating-linear-gradient(135deg, transparent 0 12px, rgba(215,25,32,.24) 12px 14px); }
.ap-placeholder-inner::before { content: ""; position: absolute; inset: 24%; border-radius: 50%; border: 1px solid var(--ap-line-strong); }
.ap-badge { position: absolute; z-index: 2; top: 14px; left: 14px; border-radius: 999px; background: rgba(215,25,32,.94); color: #fff; padding: 6px 10px; font-size: 11px; font-weight: 900; text-transform: uppercase; letter-spacing: .08em; }
.ap-card-body { padding: 20px; }
.ap-card h2, .ap-card h3 { margin: 0; font-family: var(--ap-display); font-size: clamp(22px, 2.2vw, 30px); line-height: 1.02; letter-spacing: -.055em; }
.ap-card p { margin: 12px 0 0; color: var(--ap-muted); font-size: 14px; }
.ap-meta { display: flex; flex-wrap: wrap; gap: 8px; margin-top: 16px; }
.ap-meta span { border: 1px solid var(--ap-line); color: var(--ap-muted); border-radius: 999px; padding: 5px 9px; font-size: 11px; font-weight: 900; letter-spacing: .04em; text-transform: uppercase; }
.ap-card-links { display: flex; flex-wrap: wrap; gap: 8px; margin-top: 18px; }
.ap-card-links a, .ap-mini-link { border-bottom: 1px solid currentColor; color: var(--ap-accent); font-size: 13px; font-weight: 900; }
.ap-card-collection { min-height: 350px; display: flex; flex-direction: column; }
.ap-card-collection .ap-card-media { aspect-ratio: 21/9; }
.ap-card-collection .ap-card-body { margin-top: auto; }

/* Feature strip */
.ap-feature-strip {
  display: grid; grid-template-columns: repeat(3, 1fr); gap: 1px; overflow: hidden;
  border: 1px solid var(--ap-line); border-radius: var(--ap-radius-xl); background: var(--ap-line); box-shadow: var(--ap-shadow);
}
.ap-feature { background: var(--ap-card); padding: clamp(24px, 4vw, 42px); min-height: 240px; }
.ap-feature-icon { width: 46px; height: 46px; border-radius: 16px; border: 1px solid var(--ap-line-strong); display: grid; place-items: center; color: var(--ap-accent); margin-bottom: 24px; }
.ap-feature h3 { margin: 0; font-family: var(--ap-display); font-size: 30px; line-height: 1.02; letter-spacing: -.055em; }
.ap-feature p { margin: 14px 0 0; color: var(--ap-muted); }

/* Content */
.ap-content-wrap { width: min(860px, calc(100% - 40px)); margin: 0 auto; padding: clamp(44px, 7vw, 86px) 0; }
.ap-content { color: var(--ap-text); }
.ap-content h1, .ap-content h2, .ap-content h3 { font-family: var(--ap-display); line-height: 1.05; letter-spacing: -.05em; }
.ap-content h1 { font-size: clamp(40px, 6vw, 76px); }
.ap-content h2 { font-size: clamp(28px, 4vw, 46px); margin-top: 46px; }
.ap-content p, .ap-content li { color: var(--ap-muted); font-size: 17px; }
.ap-content a { color: var(--ap-accent); font-weight: 800; }
.ap-article-hero { padding: clamp(46px, 7vw, 96px) 0 22px; }
.ap-post-meta { display: flex; gap: 10px; flex-wrap: wrap; color: var(--ap-muted); font-size: 13px; font-weight: 800; text-transform: uppercase; letter-spacing: .08em; }

/* Single model */
.ap-single-grid { display: grid; grid-template-columns: minmax(0, 1.1fr) 380px; gap: 28px; align-items: start; }
.ap-single-media { border: 1px solid var(--ap-line); border-radius: var(--ap-radius-xl); overflow: hidden; background: var(--ap-card); box-shadow: var(--ap-shadow); }
.ap-single-media img { width: 100%; aspect-ratio: 16/11; object-fit: cover; }
.ap-sidebar-card { position: sticky; top: 96px; border: 1px solid var(--ap-line); border-radius: var(--ap-radius-lg); background: var(--ap-card); padding: 22px; }
.ap-info-list { display: grid; gap: 12px; margin: 18px 0; }
.ap-info-list div { display: flex; justify-content: space-between; gap: 16px; padding-bottom: 12px; border-bottom: 1px solid var(--ap-line); }
.ap-info-list dt { color: var(--ap-muted); font-weight: 800; font-size: 13px; }
.ap-info-list dd { margin: 0; text-align: right; font-weight: 900; }
.ap-platform-grid { display: grid; gap: 10px; }
.ap-platform-grid a { width: 100%; }

/* Forms */
.ap-newsletter { display: flex; gap: 8px; margin-top: 18px; }
.ap-newsletter input { min-width: 0; flex: 1; border: 1px solid var(--ap-line); border-radius: 999px; background: var(--ap-bg); color: var(--ap-text); padding: 0 16px; min-height: 46px; }
.ap-newsletter button { border: 0; border-radius: 999px; background: var(--ap-accent); color: #fff; padding: 0 16px; font-weight: 900; cursor: pointer; }

/* Footer */
.ap-footer { border-top: 1px solid var(--ap-line); background: color-mix(in srgb, var(--ap-card) 74%, var(--ap-bg)); }
.ap-footer-grid { padding: 48px 0; display: grid; grid-template-columns: 1.5fr repeat(3, minmax(0, .7fr)) 1.15fr; gap: 28px; }
.ap-footer h3, .ap-footer h4 { margin: 0 0 14px; text-transform: uppercase; letter-spacing: .13em; font-size: 13px; }
.ap-footer p, .ap-footer a { color: var(--ap-muted); font-size: 14px; }
.ap-footer a:hover { color: var(--ap-accent); }
.ap-footer ul { list-style: none; padding: 0; margin: 0; display: grid; gap: 8px; }
.ap-footer-bottom { border-top: 1px solid var(--ap-line); padding: 16px 0; color: var(--ap-soft); font-size: 13px; }

/* Animation */
.ap-reveal { opacity: 0; transform: translateY(18px); transition: opacity .65s ease, transform .65s ease; }
.ap-reveal.is-visible { opacity: 1; transform: translateY(0); }
.ap-motion-calm .ap-reveal { transform: translateY(8px); transition-duration: .38s; }
.ap-motion-none .ap-reveal { opacity: 1; transform: none; transition: none; }
.ap-motion-none .ap-card, .ap-motion-none .ap-btn, .ap-motion-none .ap-platform-card { transition: none; }
@media (prefers-reduced-motion: reduce) {
  * { scroll-behavior: auto !important; animation: none !important; transition: none !important; }
  .ap-reveal { opacity: 1; transform: none; }
}

/* Responsive */
@media (max-width: 1080px) {
  .ap-hero-grid, .ap-single-grid { grid-template-columns: 1fr; }
  .ap-hero-panel { min-height: 500px; }
  .ap-sidebar-card { position: static; }
  .ap-gallery { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .ap-footer-grid { grid-template-columns: 1.2fr 1fr 1fr; }
}
@media (max-width: 900px) {
  .ap-mobile-toggle { display: inline-flex; }
  .ap-nav-wrap {
    position: fixed; inset: 76px 12px auto 12px; max-height: calc(100vh - 96px); overflow: auto;
    display: none; flex-direction: column; align-items: stretch; gap: 12px; padding: 14px;
    border: 1px solid var(--ap-line); border-radius: 22px; background: var(--ap-bg); box-shadow: var(--ap-shadow);
  }
  .ap-nav-wrap.is-open { display: flex; }
  .ap-menu { flex-direction: column; align-items: stretch; gap: 4px; }
  .ap-menu a { width: 100%; justify-content: space-between; padding: 13px 14px; }
  .ap-header-tools { justify-content: space-between; }
  .ap-cta { display: none; }
}
@media (max-width: 760px) {
  .ap-container { width: min(100% - 28px, var(--ap-max)); }
  .ap-header-inner { min-height: 68px; }
  .ap-brand-tag { display: none; }
  .ap-nav-wrap { inset-top: 68px; }
  .ap-hero { padding-top: 34px; }
  .ap-hero-panel { min-height: 430px; border-radius: 24px; }
  .ap-showcase { inset: 14px; gap: 12px; grid-template-columns: 1fr 1fr; }
  .ap-art-card { border-radius: 18px; padding: 14px; }
  .ap-art-card.large { min-height: 350px; }
  .ap-art-card.large .ap-art-media { inset: 16px 16px 106px; }
  .ap-art-card:not(.large) .ap-art-media { inset: 12px 12px 78px; }
  .ap-bookmark { inset: 18px 20px auto; height: 68%; }
  .ap-art-label strong { font-size: 20px; }
  .ap-stats { grid-template-columns: 1fr; }
  .ap-section-head { display: block; }
  .ap-filterbar { margin-top: 20px; overflow-x: auto; flex-wrap: nowrap; padding-bottom: 4px; }
  .ap-gallery, .ap-gallery.ap-gallery-collections { grid-template-columns: 1fr; }
  .ap-feature-strip { grid-template-columns: 1fr; }
  .ap-footer-grid { grid-template-columns: 1fr; padding: 36px 0; }
  .ap-newsletter { flex-direction: column; }
  .ap-newsletter button { min-height: 46px; }
}

@media (max-width: 760px) {
  .ap-brand-logo { max-height: min(var(--ap-logo-max-height, 42px), 44px); max-width: 46vw; }
  .ap-brand-mark { width: min(var(--ap-brand-mark-size, 38px), 42px); height: min(var(--ap-brand-mark-size, 38px), 42px); }
  .ap-brand-name { max-width: 44vw; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
}
@media (max-width: 420px) {
  .ap-title { font-size: clamp(38px, 15vw, 56px); }
  .ap-buttons { align-items: stretch; }
  .ap-btn { width: 100%; }
  .ap-lang { display: flex; }
  .ap-lang a { min-width: 34px; padding: 0 8px; }
}

/* Homepage full-control additions */
.ap-hero-grid-solo { grid-template-columns: minmax(0, 900px); justify-content: center; text-align: center; }
.ap-hero-grid-solo .ap-lead { margin-inline: auto; }
.ap-hero-grid-solo .ap-buttons { justify-content: center; }
.ap-hero-grid-solo .ap-stats { max-width: 760px; margin-inline: auto; }
.ap-platform-section { padding-top: 0; }
.ap-platform-section .ap-platform-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 14px;
}
.ap-platform-card {
  min-height: 142px;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  border: 1px solid var(--ap-line);
  border-radius: var(--ap-card-radius-custom, var(--ap-radius-lg));
  background: linear-gradient(180deg, var(--ap-card), var(--ap-card-2));
  padding: 20px;
  transition: transform .24s ease, border-color .24s ease, box-shadow .24s ease;
}
.ap-platform-card:hover {
  transform: translateY(-4px);
  border-color: color-mix(in srgb, var(--ap-accent) 55%, var(--ap-line));
  box-shadow: var(--ap-glow);
  color: var(--ap-text);
}
.ap-platform-card strong {
  font-family: var(--ap-display);
  font-size: 24px;
  line-height: 1;
  letter-spacing: -.055em;
}
.ap-platform-card span { color: var(--ap-muted); font-size: 14px; margin-top: 18px; }
.ap-platform-card.is-disabled { opacity: .58; cursor: default; }
.ap-platform-card.is-disabled:hover { transform: none; box-shadow: none; border-color: var(--ap-line); }

@media (max-width: 1080px) {
  .ap-platform-section .ap-platform-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
}
@media (max-width: 760px) {
  .ap-platform-section .ap-platform-grid { grid-template-columns: 1fr; }
}

/* Platform card customization v4.7.0 */
.ap-platform-grid.ap-platform-align-center .ap-platform-card { text-align: center; }
.ap-platform-grid.ap-platform-align-center .ap-platform-brand { align-items: center; }
.ap-platform-card {
  position: relative;
  overflow: hidden;
  isolation: isolate;
  background: var(--ap-platform-bg-image, linear-gradient(180deg, var(--ap-card), var(--ap-card-2)));
  background-size: cover;
  background-position: center;
}
.ap-platform-card::before {
  content: "";
  position: absolute;
  inset: 0;
  background: var(--ap-platform-overlay);
  opacity: 0;
  z-index: -1;
  transition: opacity .24s ease;
}
.ap-platform-card.has-bg::before { opacity: 1; }
.ap-platform-card::after {
  content: "";
  position: absolute;
  inset: auto 18px 18px 18px;
  height: 1px;
  background: color-mix(in srgb, var(--ap-accent) 55%, transparent);
  opacity: .55;
  z-index: -1;
}
.ap-platform-content {
  min-height: 100%;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  gap: 18px;
  position: relative;
  z-index: 2;
}
.ap-platform-bg { display: none; }
.ap-platform-brand {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 12px;
}
.ap-platform-logo {
  max-width: 155px;
  max-height: 40px;
  object-fit: contain;
  object-position: left center;
  filter: drop-shadow(0 8px 18px rgba(0,0,0,.25));
}
.ap-platform-logo-small .ap-platform-logo { max-width: 116px; max-height: 30px; }
.ap-platform-logo-large .ap-platform-logo { max-width: 210px; max-height: 58px; }
.ap-platform-card strong {
  font-family: var(--ap-platform-title-font);
  color: var(--ap-platform-title-color);
}
.ap-platform-card .ap-platform-description {
  font-family: var(--ap-platform-text-font);
  color: var(--ap-platform-text-color);
  font-size: 14px;
  line-height: 1.5;
  margin-top: 0;
}
.ap-platform-card.has-bg {
  min-height: 170px;
  border-color: color-mix(in srgb, var(--ap-platform-title-color) 14%, var(--ap-line));
}
.ap-platform-card.has-bg:hover {
  box-shadow: 0 22px 70px color-mix(in srgb, var(--ap-accent) 18%, transparent);
}

/* =========================================================
   Archiprints Editorial Studio visual skin — v4.8.0
   Keeps all Customizer controls and features, changes only visuals.
   Palette preserved: black / gray / white / red.
   ========================================================= */
:root {
  --ap-accent: #b11226;
  --ap-accent-2: #e21d2f;
  --ap-radius-xl: 18px;
  --ap-radius-lg: 14px;
  --ap-radius-md: 10px;
  --ap-radius-sm: 8px;
  --ap-max: 1320px;
  --ap-button-radius: 6px;
  --ap-card-radius-custom: 14px;
}

html[data-theme="dark"],
body.ap-theme-dark {
  --ap-bg: #050506;
  --ap-bg-2: #090a0c;
  --ap-panel: #0e0f12;
  --ap-card: #111216;
  --ap-card-2: #0a0b0d;
  --ap-text: #f4f4f5;
  --ap-muted: #a2a5ad;
  --ap-soft: #6e737d;
  --ap-line: rgba(255,255,255,.105);
  --ap-line-strong: rgba(255,255,255,.22);
  --ap-shadow: 0 28px 90px rgba(0,0,0,.42);
  --ap-glow: 0 0 0 1px rgba(177,18,38,.35), 0 28px 90px rgba(177,18,38,.16);
  --ap-gradient:
    linear-gradient(90deg, rgba(255,255,255,.035) 1px, transparent 1px) 0 0 / 72px 72px,
    radial-gradient(circle at 78% 4%, rgba(177,18,38,.20), transparent 30%),
    linear-gradient(180deg, #070709 0%, #050506 62%, #08090b 100%);
}

html[data-theme="light"],
body.ap-theme-light {
  --ap-bg: #f4f4f5;
  --ap-bg-2: #ffffff;
  --ap-panel: #ffffff;
  --ap-card: #ffffff;
  --ap-card-2: #ebedf0;
  --ap-text: #101114;
  --ap-muted: #5f636b;
  --ap-soft: #858992;
  --ap-line: rgba(16,17,20,.105);
  --ap-line-strong: rgba(16,17,20,.22);
  --ap-shadow: 0 28px 84px rgba(20,22,28,.11);
  --ap-glow: 0 0 0 1px rgba(177,18,38,.24), 0 28px 80px rgba(177,18,38,.10);
  --ap-gradient:
    linear-gradient(90deg, rgba(16,17,20,.045) 1px, transparent 1px) 0 0 / 72px 72px,
    radial-gradient(circle at 78% 4%, rgba(177,18,38,.10), transparent 30%),
    linear-gradient(180deg, #ffffff 0%, #f4f4f5 72%, #ffffff 100%);
}

.ap-shell { background: var(--ap-gradient); }
.ap-container { width: min(var(--ap-max), calc(100% - 48px)); }
.ap-section { padding: clamp(64px, 9vw, 132px) 0; }
.ap-section-tight { padding: clamp(44px, 7vw, 96px) 0; }
.ap-eyebrow {
  font-size: 11px;
  letter-spacing: .28em;
  font-weight: 950;
  margin-bottom: 18px;
}
.ap-eyebrow::before { width: 42px; height: 3px; }
.ap-title {
  letter-spacing: -.075em;
  line-height: .88;
  font-weight: 950;
  text-wrap: balance;
}
.ap-lead {
  max-width: 720px;
  color: color-mix(in srgb, var(--ap-muted) 88%, var(--ap-text));
}

/* Header: editorial rail instead of soft pill look */
.ap-site-header {
  background: color-mix(in srgb, var(--ap-bg) 90%, transparent);
  border-bottom: 1px solid var(--ap-line);
  box-shadow: 0 8px 28px rgba(0,0,0,.06);
}
.ap-header-inner { min-height: var(--ap-header-min-height, 78px); }
.ap-brand { gap: 14px; }
.ap-brand-mark {
  border-radius: 0;
  border: 1px solid var(--ap-line-strong);
  background: var(--ap-text);
  color: var(--ap-bg);
  box-shadow: inset 6px 0 0 var(--ap-accent);
}
.ap-brand-mark-style-circle .ap-brand-mark { border-radius: 999px; }
.ap-brand-mark-style-slash .ap-brand-mark::before { width: 7px; }
.ap-brand-name { font-weight: 950; letter-spacing: var(--ap-brand-letter-spacing, .18em); }
.ap-brand-tag { letter-spacing: .22em; }
.ap-menu { gap: 2px; }
.ap-menu a {
  border-radius: 0;
  padding: 13px 13px 12px;
  text-transform: uppercase;
  letter-spacing: .075em;
  font-size: 12px;
  background: transparent !important;
}
.ap-menu a:hover,
.ap-menu .current-menu-item > a,
.ap-menu .current_page_item > a { color: var(--ap-accent); }
.ap-tool-btn,
.ap-mobile-toggle,
.ap-lang a,
.ap-cta {
  border-radius: 0;
  min-height: 42px;
  background: transparent;
  border-color: var(--ap-line-strong);
  text-transform: uppercase;
  letter-spacing: .07em;
}
.ap-lang .current-lang a,
.ap-cta { background: var(--ap-accent); color: #fff; border-color: var(--ap-accent); }
.ap-cta { box-shadow: none; }

/* Buttons: sharp studio controls */
.ap-buttons { margin-top: 34px; }
.ap-btn {
  border-radius: var(--ap-button-radius, 6px);
  min-height: 52px;
  padding: 0 22px;
  text-transform: uppercase;
  letter-spacing: .055em;
  font-size: 12px;
}
.ap-btn-primary { box-shadow: none; }
.ap-btn:hover { transform: translateY(-2px); }

/* Hero: split editorial composition */
.ap-hero { padding: clamp(48px, 7vw, 108px) 0 clamp(56px, 8vw, 112px); }
.ap-hero-grid {
  grid-template-columns: minmax(0, .92fr) minmax(390px, 1.08fr);
  gap: clamp(36px, 6vw, 86px);
  align-items: stretch;
}
.ap-hero-grid > .ap-reveal:first-child {
  position: relative;
  display: flex;
  flex-direction: column;
  justify-content: center;
  min-height: min(640px, 76vh);
  padding: clamp(26px, 4vw, 58px) 0 clamp(26px, 4vw, 58px) clamp(18px, 3vw, 42px);
}
.ap-hero-grid > .ap-reveal:first-child::before {
  content: "";
  position: absolute;
  left: 0;
  top: clamp(18px, 5vw, 54px);
  bottom: clamp(18px, 5vw, 54px);
  width: 5px;
  background: var(--ap-accent);
}
.ap-hero-panel {
  min-height: min(660px, 78vh);
  border-radius: 0;
  border-color: var(--ap-line-strong);
  background:
    linear-gradient(135deg, color-mix(in srgb, var(--ap-text) 4%, transparent) 25%, transparent 25% 50%, color-mix(in srgb, var(--ap-text) 4%, transparent) 50% 75%, transparent 75%) 0 0 / 18px 18px,
    linear-gradient(145deg, var(--ap-card), var(--ap-card-2));
  box-shadow: var(--ap-shadow);
}
.ap-hero-panel::before {
  background:
    linear-gradient(90deg, var(--ap-accent) 0 5px, transparent 5px),
    radial-gradient(circle at 78% 16%, rgba(177,18,38,.22), transparent 28%);
}
.ap-showcase {
  inset: 24px;
  display: grid;
  grid-template-columns: 1.05fr .82fr;
  grid-template-rows: 1fr 1fr;
  gap: 14px;
}
.ap-art-card {
  border-radius: 0;
  padding: 0;
  border-color: var(--ap-line-strong);
  background: var(--ap-card);
  box-shadow: none;
}
.ap-art-card.large { min-height: 470px; }
.ap-art-card::after {
  inset: auto 0 0 0;
  height: 45%;
  background: linear-gradient(0deg, rgba(0,0,0,.78), transparent);
  z-index: 2;
}
html[data-theme="light"] .ap-art-card::after,
body.ap-theme-light .ap-art-card::after { background: linear-gradient(0deg, rgba(255,255,255,.88), transparent); }
.ap-art-media,
.ap-art-card.large .ap-art-media,
.ap-art-card:not(.large) .ap-art-media {
  inset: 0;
  border: 0;
  border-radius: 0;
}
.ap-art-media img,
.ap-art-image,
.ap-card-media img {
  filter: grayscale(.92) contrast(1.08);
  transition: transform .55s ease, filter .35s ease;
}
.ap-art-card:hover .ap-art-media img,
.ap-card:hover .ap-card-media img { transform: scale(1.045); filter: grayscale(.55) contrast(1.08); }
.ap-art-label,
.ap-art-card.large .ap-art-label {
  left: 22px;
  right: 22px;
  bottom: 20px;
  z-index: 4;
}
.ap-art-label strong { font-size: clamp(24px, 2.8vw, 42px); letter-spacing: -.07em; }
.ap-art-card:not(.large) .ap-art-label strong { font-size: clamp(20px, 2vw, 28px); }
.ap-art-label span { color: color-mix(in srgb, var(--ap-muted) 82%, var(--ap-text)); }
.ap-bookmark,
.ap-mini-sculpture { opacity: .86; }

.ap-stats {
  display: flex;
  flex-wrap: wrap;
  gap: 0;
  border: 1px solid var(--ap-line);
  width: fit-content;
  max-width: 100%;
}
.ap-stat {
  border-left: 0;
  border-right: 1px solid var(--ap-line);
  padding: 14px 18px;
  min-width: 132px;
}
.ap-stat:last-child { border-right: 0; }
.ap-stat strong { font-size: 20px; }
.ap-stat span { letter-spacing: .12em; }

/* Gallery: magazine cards */
.ap-section-head {
  align-items: start;
  border-top: 1px solid var(--ap-line-strong);
  padding-top: 26px;
}
.ap-gallery { gap: 16px; }
.ap-gallery.ap-gallery-collections { gap: 16px; }
.ap-card {
  border-radius: 0;
  background: var(--ap-card);
  box-shadow: none;
  border-color: var(--ap-line-strong);
}
.ap-card:hover { transform: translateY(-4px); box-shadow: var(--ap-glow); }
.ap-card-media {
  aspect-ratio: 4 / 3;
  border-bottom: 1px solid var(--ap-line-strong);
}
.ap-card-collection .ap-card-media { aspect-ratio: 16 / 9; }
.ap-card-media::before {
  background:
    linear-gradient(180deg, transparent 45%, rgba(0,0,0,.32)),
    linear-gradient(90deg, var(--ap-accent) 0 4px, transparent 4px);
  z-index: 1;
}
.ap-card-body { padding: 24px; }
.ap-card h2,
.ap-card h3 { letter-spacing: -.07em; font-weight: 900; }
.ap-card p { font-size: 14px; line-height: 1.55; }
.ap-badge {
  top: 0;
  left: 0;
  border-radius: 0;
  padding: 8px 12px;
  background: var(--ap-accent);
}
.ap-meta span { border-radius: 0; }
.ap-card-links a,
.ap-mini-link { text-transform: uppercase; letter-spacing: .08em; font-size: 11px; }
.ap-placeholder-inner { border-radius: 0; }

/* Feature strip: architectural grid */
.ap-feature-strip {
  border-radius: 0;
  box-shadow: none;
  border-color: var(--ap-line-strong);
}
.ap-feature { position: relative; overflow: hidden; }
.ap-feature::after {
  content: "";
  position: absolute;
  inset: auto 24px 24px auto;
  width: 58px;
  height: 58px;
  border-right: 3px solid var(--ap-accent);
  border-bottom: 3px solid var(--ap-accent);
  opacity: .32;
}
.ap-feature-icon { border-radius: 0; width: 50px; height: 50px; }
.ap-feature h3 { letter-spacing: -.07em; }

/* Platform cards: logo-first external link blocks */
.ap-platform-section .ap-platform-grid { gap: 16px; }
.ap-platform-card {
  border-radius: 0;
  min-height: 190px;
  padding: 22px;
  border-color: var(--ap-line-strong);
  box-shadow: none;
}
.ap-platform-card::after {
  inset: auto 22px 22px 22px;
  background: var(--ap-accent);
  height: 3px;
  opacity: .75;
}
.ap-platform-card:hover { transform: translateY(-4px); }
.ap-platform-brand { gap: 14px; }
.ap-platform-logo { max-height: 46px; filter: drop-shadow(0 12px 24px rgba(0,0,0,.38)); }
.ap-platform-card strong { letter-spacing: -.06em; font-size: 26px; }
.ap-platform-card .ap-platform-description { font-size: 13px; line-height: 1.55; }

/* Footer: stronger black band */
.ap-footer {
  background: #050506;
  color: #f4f4f5;
  border-top: 4px solid var(--ap-accent);
}
.ap-footer p,
.ap-footer a { color: #a7aab2; }
.ap-footer h3,
.ap-footer h4 { color: #fff; }
.ap-footer-bottom { border-top-color: rgba(255,255,255,.10); color: #777b84; }

/* Mobile editorial refinements */
@media (max-width: 1080px) {
  .ap-hero-grid { grid-template-columns: 1fr; }
  .ap-hero-grid > .ap-reveal:first-child { min-height: auto; }
  .ap-hero-panel { min-height: 560px; }
}
@media (max-width: 900px) {
  .ap-nav-wrap {
    border-radius: 0;
    inset: 78px 12px auto 12px;
    background: var(--ap-bg);
  }
  .ap-menu a { border-bottom: 1px solid var(--ap-line); }
}
@media (max-width: 760px) {
  .ap-container { width: min(100% - 30px, var(--ap-max)); }
  .ap-hero-grid > .ap-reveal:first-child { padding-left: 18px; }
  .ap-hero-grid > .ap-reveal:first-child::before { top: 0; bottom: 0; width: 4px; }
  .ap-hero-panel { min-height: 520px; }
  .ap-showcase { inset: 12px; grid-template-columns: 1fr; grid-template-rows: 1.05fr .7fr .7fr; }
  .ap-art-card.large { min-height: auto; grid-row: auto; }
  .ap-art-label strong { font-size: 24px; }
  .ap-stats { width: 100%; display: grid; grid-template-columns: 1fr; }
  .ap-stat { border-right: 0; border-bottom: 1px solid var(--ap-line); }
  .ap-stat:last-child { border-bottom: 0; }
  .ap-section-head { display: block; }
}
@media (max-width: 420px) {
  .ap-title { font-size: clamp(42px, 14.5vw, 58px); }
  .ap-hero-panel { min-height: 480px; }
  .ap-tool-btn, .ap-mobile-toggle, .ap-lang a { min-height: 38px; }
}
