/* ================================================================
   PONDOK BCS — Unified Design System v2
   Landing + Admin share ONE color palette
   Warm Terracotta / Gold on Cream  ↔  Deep Indigo on Navy (dark)
================================================================ */
@import url('https://fonts.googleapis.com/css2?family=Playfair+Display:ital,wght@0,400;0,600;0,700;1,400&family=Plus+Jakarta+Sans:wght@300;400;500;600;700&display=swap');

/* ── LIGHT THEME ─────────────────────────────────────────────── */
:root,[data-theme="light"]{
  --bg:        #faf8f4; --bg2: #ffffff; --bg3: #f5f0e8; --bg4: #ede8df;
  --text:      #1a1208; --text2: #4a3728; --muted: #9b7d6a;
  --accent:    #c05a2b; --accent2: #e07a4b; --accent-glow: rgba(192,90,43,.15);
  --gold:      #d4a843; --gold2: #e8c46a; --gold-glow: rgba(212,168,67,.15);
  --border:    #e5ddd4; --border2: #f0ebe3;
  --shadow-sm: 0 2px 12px rgba(192,90,43,.07);
  --shadow-md: 0 8px 32px rgba(192,90,43,.11);
  --shadow-lg: 0 20px 60px rgba(192,90,43,.15);
  --grad-accent: linear-gradient(135deg,#c05a2b,#e07a4b);
  --grad-gold:   linear-gradient(135deg,#d4a843,#e8c46a);
  --grad-hero:   linear-gradient(135deg,#faf8f4,#f5ede3,#faf0e8);
  --font-heading: 'Playfair Display',serif;
  --font-body:    'Plus Jakarta Sans',sans-serif;
  --nav-h: 70px; --r-sm:8px; --r-md:14px; --r-lg:20px; --r-xl:28px;
  --tr: 0.28s cubic-bezier(.4,0,.2,1);
  /* Admin sidebar vars (same palette) */
  --sb-bg:    #1a1208; --sb-bg2: #231809; --sb-text: #e8ddd4;
  --sb-muted: #7a6050; --sb-active: rgba(192,90,43,.18);
  --sb-accent: #e07a4b;
  --danger:#ef4444; --success:#22c55e; --warning:#f59e0b; --info:#3b82f6;
}

/* ── DARK THEME ──────────────────────────────────────────────── */
[data-theme="dark"]{
  --bg:        #0e0b18; --bg2: #14102a; --bg3: #1a1530; --bg4: #201c3a;
  --text:      #f0ebe3; --text2: #c4b49a; --muted: #6b5c4a;
  --accent:    #d4a843; --accent2: #e8c46a; --accent-glow: rgba(212,168,67,.18);
  --gold:      #d4a843; --gold2: #e8c46a; --gold-glow: rgba(212,168,67,.18);
  --border:    #2a2040; --border2: #1e1830;
  --shadow-sm: 0 2px 12px rgba(0,0,0,.4);
  --shadow-md: 0 8px 32px rgba(0,0,0,.5);
  --shadow-lg: 0 20px 60px rgba(0,0,0,.65);
  --grad-accent: linear-gradient(135deg,#d4a843,#e8c46a);
  --grad-gold:   linear-gradient(135deg,#d4a843,#f0d070);
  --grad-hero:   linear-gradient(135deg,#0e0b18,#130f24,#0e0b18);
  --sb-bg:    #05040c; --sb-bg2: #0a0818; --sb-text: #c4b49a;
  --sb-muted: #4a3a2a; --sb-active: rgba(212,168,67,.15);
  --sb-accent: #e8c46a;
  --danger:#ff4d6d; --success:#00e5a0; --warning:#ffb703; --info:#60a5fa;
}

/* ── RESET ───────────────────────────────────────────────────── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;font-size:16px}
body{font-family:var(--font-body);background:var(--bg);color:var(--text);line-height:1.7;overflow-x:hidden;transition:background var(--tr),color var(--tr)}
img{max-width:100%;height:auto;display:block}
a{text-decoration:none;color:inherit}
ul{list-style:none}
::selection{background:var(--accent);color:#fff}
::-webkit-scrollbar{width:6px}
::-webkit-scrollbar-track{background:var(--bg)}
::-webkit-scrollbar-thumb{background:var(--accent);border-radius:10px}
h1,h2,h3,h4{font-family:var(--font-heading);line-height:1.2;color:var(--text)}

/* ── UTILITIES ───────────────────────────────────────────────── */
.container{max-width:1180px;margin:0 auto;padding:0 24px}
.section-label{display:inline-flex;align-items:center;gap:8px;font-size:.75rem;font-weight:700;letter-spacing:.18em;text-transform:uppercase;color:var(--accent);margin-bottom:12px}
.section-label::before{content:'';width:22px;height:2px;background:var(--accent);border-radius:2px}
.section-title{font-size:clamp(1.8rem,4vw,2.8rem);margin-bottom:12px}
.section-subtitle{font-size:1rem;color:var(--muted);max-width:520px;margin:0 auto 52px}
.section-header{text-align:center;margin-bottom:52px}

/* ── BUTTONS ─────────────────────────────────────────────────── */
.btn{display:inline-flex;align-items:center;gap:8px;padding:11px 24px;border-radius:var(--r-md);font-family:var(--font-body);font-size:.9rem;font-weight:600;cursor:pointer;border:none;transition:all var(--tr);white-space:nowrap;position:relative;overflow:hidden}
.btn::after{content:'';position:absolute;inset:0;background:rgba(255,255,255,.1);opacity:0;transition:opacity var(--tr)}
.btn:hover::after{opacity:1}
.btn-primary{background:var(--grad-accent);color:#fff;box-shadow:0 4px 18px var(--accent-glow)}
.btn-primary:hover{transform:translateY(-2px);box-shadow:0 8px 28px var(--accent-glow)}
.btn-gold{background:var(--grad-gold);color:#1a1208;font-weight:700}
.btn-outline{background:transparent;color:var(--accent);border:2px solid var(--accent)}
.btn-outline:hover{background:var(--accent);color:#fff}

/* ── WHATSAPP BUTTONS ──────────────────────────────────────────── */
.btn-wa-sm{display:inline-flex;align-items:center;gap:8px;padding:10px 22px;background:linear-gradient(135deg,#25d366,#128c7e);color:#fff;border-radius:var(--r-md);font-family:var(--font-body);font-size:.88rem;font-weight:700;text-decoration:none;transition:all var(--tr);border:none;cursor:pointer;white-space:nowrap}
.btn-wa-sm:hover{transform:translateY(-2px);box-shadow:0 6px 20px rgba(37,211,102,.35);color:#fff}
.btn-wa-sm i{font-size:1rem}

.btn-ghost{background:transparent;color:var(--text2);border:1.5px solid var(--border)}
.btn-ghost:hover{border-color:var(--accent);color:var(--accent)}
.btn-sm{padding:6px 14px;font-size:.8rem;border-radius:var(--r-sm)}
.btn-success{background:linear-gradient(135deg,#22c55e,#16a34a);color:#fff}
.btn-danger{background:linear-gradient(135deg,#ef4444,#dc2626);color:#fff}
.btn-info{background:linear-gradient(135deg,#3b82f6,#2563eb);color:#fff}

/* ── NAVBAR ──────────────────────────────────────────────────── */
.navbar{position:fixed;top:0;left:0;right:0;z-index:1000;background:rgba(250,248,244,.94);backdrop-filter:blur(16px);border-bottom:1px solid var(--border2);height:var(--nav-h);transition:all var(--tr)}
[data-theme="dark"] .navbar{background:rgba(14,11,24,.94)}
.navbar.scrolled{box-shadow:var(--shadow-md)}
.nav-container{display:flex;align-items:center;justify-content:space-between;height:var(--nav-h)}
.nav-logo{font-family:var(--font-heading);font-size:1.45rem;font-weight:700;color:var(--text);display:flex;align-items:center;gap:7px}
.nav-logo i{color:var(--accent);font-size:1.25rem}
.nav-logo span{color:var(--accent)}
.nav-links{display:flex;align-items:center;gap:2px}
.nav-links li{position:relative}
.nav-links a{font-size:.875rem;font-weight:500;color:var(--text2);padding:8px 13px;border-radius:var(--r-sm);display:flex;align-items:center;gap:5px;transition:all var(--tr)}
.nav-links a:hover,.nav-links a.active{color:var(--accent);background:var(--accent-glow)}
.nav-links .nav-arrow{font-size:.6rem;transition:transform var(--tr)}
.nav-links li:hover>.nav-arrow,.nav-links li:hover>a .nav-arrow{transform:rotate(180deg)}
.nav-dropdown{position:absolute;top:calc(100% + 8px);left:0;background:var(--bg2);border:1px solid var(--border);border-radius:var(--r-md);min-width:210px;padding:8px;box-shadow:var(--shadow-lg);opacity:0;visibility:hidden;transform:translateY(-6px);transition:all .22s cubic-bezier(.4,0,.2,1);z-index:200}
.nav-links li:hover .nav-dropdown{opacity:1;visibility:visible;transform:translateY(0)}
.nav-dropdown a{display:flex;align-items:center;gap:10px;padding:10px 13px;border-radius:var(--r-sm);font-size:.855rem;color:var(--text2);transition:all var(--tr)}
.nav-dropdown a:hover{background:var(--accent-glow);color:var(--accent)}
.nav-dropdown a i{width:18px;text-align:center;color:var(--accent);font-size:.9rem}
.nav-dropdown .cat-icon-img{width:20px;height:20px;border-radius:4px;object-fit:cover}
.nav-controls{display:flex;align-items:center;gap:8px}
.lang-toggle{display:flex;align-items:center;gap:3px}
.lang-btn{font-size:.75rem;font-weight:700;padding:5px 9px;border-radius:var(--r-sm);color:var(--muted);transition:all var(--tr)}
.lang-btn:hover,.lang-btn.active{color:var(--accent);background:var(--accent-glow)}
.lang-sep{color:var(--border);font-size:.8rem}
.theme-toggle{width:36px;height:36px;border-radius:var(--r-sm);background:transparent;border:1.5px solid var(--border);color:var(--muted);cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:.9rem;transition:all var(--tr)}
.theme-toggle:hover{background:var(--accent-glow);color:var(--accent);border-color:var(--accent)}
[data-theme="dark"] .sun-icon{display:block}[data-theme="dark"] .moon-icon{display:none}
[data-theme="light"] .sun-icon{display:none}[data-theme="light"] .moon-icon{display:block}
.hamburger{display:none;flex-direction:column;gap:5px;background:none;border:none;cursor:pointer;padding:6px}
.hamburger span{display:block;width:22px;height:2px;background:var(--text);border-radius:2px;transition:all var(--tr)}
.mobile-overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,.55);z-index:1001;opacity:0;transition:opacity var(--tr)}
.mobile-overlay.active{display:block;opacity:1}
.mobile-nav{position:fixed;top:0;right:-100%;width:min(300px,85vw);height:100vh;background:var(--bg2);z-index:1002;padding:72px 20px 40px;overflow-y:auto;transition:right .32s cubic-bezier(.4,0,.2,1);border-left:1px solid var(--border)}
.mobile-nav.active{right:0}
.mobile-nav-close{position:absolute;top:18px;right:18px;width:36px;height:36px;border-radius:var(--r-sm);background:var(--bg3);border:none;color:var(--text2);cursor:pointer;display:flex;align-items:center;justify-content:center}
.mobile-nav ul li a{display:block;padding:11px 14px;font-size:.92rem;font-weight:500;color:var(--text2);border-radius:var(--r-sm);transition:all var(--tr);margin-bottom:2px}
.mobile-nav ul li a:hover,.mobile-nav ul li a.active{color:var(--accent);background:var(--accent-glow)}
.mobile-sub a{font-size:.84rem;padding:8px 14px 8px 28px;color:var(--muted)}
.mobile-controls{margin-top:24px;padding-top:18px;border-top:1px solid var(--border);display:flex;align-items:center;gap:10px}

/* ── HERO ────────────────────────────────────────────────────── */
.hero{min-height:110vh;display:flex;align-items:center;background:var(--grad-hero);padding-top:var(--nav-h);position:relative;overflow:hidden}
.hero-blob{position:absolute;pointer-events:none}
.hero-blob-1{top:-10%;right:-8%;width:60vw;height:60vw;border-radius:50%;background:radial-gradient(circle,rgba(192,90,43,.07) 0%,transparent 70%)}
.hero-blob-2{bottom:-10%;left:-5%;width:44vw;height:44vw;border-radius:50%;background:radial-gradient(circle,rgba(212,168,67,.07) 0%,transparent 70%)}
.hero-inner{display:grid;grid-template-columns:1fr 1fr;gap:56px;align-items:center;padding:96px 0}
.hero-badge{display:inline-flex;align-items:center;gap:7px;background:var(--accent-glow);border:1px solid rgba(192,90,43,.2);color:var(--accent);font-size:.75rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;padding:6px 14px;border-radius:100px;margin-bottom:22px}
[data-theme="dark"] .hero-badge{background:rgba(212,168,67,.12);border-color:rgba(212,168,67,.25)}
.hero-dot{width:6px;height:6px;border-radius:50%;background:var(--accent);animation:pulse-dot 2s infinite}
.hero-title{font-size:clamp(2.6rem,5.5vw,4rem);line-height:1.1;margin-bottom:18px}
.hero-title .italic{font-style:italic;color:var(--accent)}
.hero-sub{font-size:1.05rem;color:var(--text2);max-width:460px;margin-bottom:32px;line-height:1.75}
.hero-actions{display:flex;gap:12px;flex-wrap:wrap}
.hero-stats{display:flex;gap:28px;margin-top:44px;padding-top:32px;border-top:1px solid var(--border)}
.stat-val{font-family:var(--font-heading);font-size:1.9rem;font-weight:700;color:var(--accent);display:block}
.stat-lbl{font-size:.8rem;color:var(--muted);font-weight:500}
/* ── HERO CAROUSEL ───────────────────────────────────────────── */
.hero-carousel-wrap{display:flex;flex-direction:column;gap:12px;position:relative}
.hero-carousel{display:grid;grid-template-columns:1fr 1fr;gap:12px;min-height:300px}
/* Cards animation */
.hero-card{background:var(--bg2);border-radius:var(--r-lg);border:1px solid var(--border);overflow:hidden;box-shadow:var(--shadow-md);transition:transform var(--tr),opacity .4s ease,scale .4s ease;cursor:pointer;text-decoration:none;display:flex;flex-direction:column}
.hero-card.visible{opacity:1;scale:1;animation:heroCardIn .45s ease both}
.hero-card.hidden-slide{display:none;opacity:0;scale:.95}
.hero-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg)}
@keyframes heroCardIn{from{opacity:0;transform:translateY(10px) scale(.97)}to{opacity:1;transform:translateY(0) scale(1)}}
/* Image wrapper — preserves aspect ratio, no cropping */
.hero-card-img-wrap{overflow:hidden;background:var(--bg3);flex:1;display:flex;align-items:center;justify-content:center}
.hero-card-img-wrap.portrait {aspect-ratio:3/4;max-height:200px}
.hero-card-img-wrap.landscape{aspect-ratio:16/9;max-height:160px}
.hero-card-img-wrap.square   {aspect-ratio:1/1;max-height:180px}
.hero-card-img-wrap img{width:100%;height:100%;object-fit:cover;object-position:center;display:block}
.hero-card-placeholder{width:100%;height:100%;min-height:120px;display:flex;align-items:center;justify-content:center;font-size:2rem;color:var(--muted);background:linear-gradient(135deg,var(--border),var(--bg3))}
.hero-card-info{padding:10px 13px;flex-shrink:0}
.hero-card-name{font-size:.78rem;font-weight:600;color:var(--text);margin-bottom:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.hero-card-price{font-size:.75rem;color:var(--accent);font-weight:700}
/* Dots */
.hero-carousel-dots{display:flex;gap:6px;justify-content:center;padding-top:4px}
.hero-dot-btn{width:8px;height:8px;border-radius:50%;background:var(--border);border:none;cursor:pointer;transition:all var(--tr);padding:0}
.hero-dot-btn.active{background:var(--accent);width:20px;border-radius:4px}

/* ── SECTIONS ────────────────────────────────────────────────── */
section{padding:88px 0}
section:nth-child(even){background:var(--bg2)}

/* ── CARDS ───────────────────────────────────────────────────── */
.card{background:var(--bg2);border-radius:var(--r-lg);border:1px solid var(--border);box-shadow:var(--shadow-sm);transition:all var(--tr)}
.card:hover{box-shadow:var(--shadow-md);transform:translateY(-3px);border-color:var(--accent-glow)}

/* ── FILTER TABS ─────────────────────────────────────────────── */
.filter-tabs{display:flex;gap:8px;margin-bottom:36px;flex-wrap:wrap}
.filter-tab{padding:8px 20px;border-radius:100px;font-size:.85rem;font-weight:600;border:1.5px solid var(--border);color:var(--text2);cursor:pointer;transition:all var(--tr);background:transparent;font-family:var(--font-body);display:flex;align-items:center;gap:7px}
.filter-tab img{width:18px;height:18px;border-radius:4px;object-fit:cover}
.filter-tab:hover,.filter-tab.active{background:var(--accent);color:#fff;border-color:var(--accent)}

/* ── PAINTINGS GRID ──────────────────────────────────────────── */
.paintings-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:22px;align-items:start}
/* Landscape paintings are naturally wider - give them span 2 if possible */
.painting-card[data-aspect="landscape"],.painting-card.landscape-card{grid-column:span 2}
@media(max-width:600px){.painting-card[data-aspect="landscape"],.painting-card.landscape-card{grid-column:span 1}}
.painting-card{background:var(--bg2);border-radius:var(--r-lg);border:1px solid var(--border);overflow:hidden;box-shadow:var(--shadow-sm);transition:all var(--tr);cursor:pointer}
.painting-card:hover{transform:translateY(-6px);box-shadow:var(--shadow-lg)}
.painting-img{position:relative;overflow:hidden;background:var(--bg3)}
/* Flexible aspect ratio — portrait (3/4) or landscape (4/3) */
.painting-img.portrait{aspect-ratio:3/4}
.painting-img.landscape{aspect-ratio:4/3}
.painting-img.square{aspect-ratio:1/1}
.painting-img img{width:100%;height:100%;object-fit:cover;transition:transform .5s ease}
.painting-card:hover .painting-img img{transform:scale(1.06)}
.painting-img-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;font-size:3rem;color:var(--muted);aspect-ratio:3/4;background:linear-gradient(135deg,var(--border),var(--bg3))}
.painting-overlay{position:absolute;inset:0;background:rgba(0,0,0,.48);display:flex;align-items:center;justify-content:center;gap:10px;opacity:0;transition:opacity var(--tr)}
.painting-card:hover .painting-overlay{opacity:1}
.p-overlay-btn{width:44px;height:44px;border-radius:50%;background:rgba(255,255,255,.15);backdrop-filter:blur(8px);border:1.5px solid rgba(255,255,255,.3);color:#fff;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all var(--tr);font-size:.95rem;text-decoration:none}
.p-overlay-btn:hover{background:var(--accent);border-color:var(--accent);transform:scale(1.12)}
.painting-badge{position:absolute;top:10px;left:10px;background:var(--accent);color:#fff;font-size:.7rem;font-weight:700;padding:3px 10px;border-radius:100px}
.painting-badge.sold{background:#6b7280}
.painting-info{padding:16px}
.painting-name{font-size:.95rem;font-weight:600;margin-bottom:6px;color:var(--text)}
.painting-meta{display:flex;align-items:center;justify-content:space-between}
.painting-size{font-size:.78rem;color:var(--muted)}
.painting-price{font-family:var(--font-heading);font-size:1.05rem;font-weight:700;color:var(--accent)}

/* ── MODAL ───────────────────────────────────────────────────── */
.modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,.72);z-index:3000;display:flex;align-items:center;justify-content:center;padding:16px;opacity:0;visibility:hidden;transition:all .25s ease;backdrop-filter:blur(4px)}
.modal-overlay.active{opacity:1;visibility:visible}
.modal{background:var(--bg2);border-radius:var(--r-xl);max-width:820px;width:100%;max-height:90vh;overflow-y:auto;box-shadow:0 40px 100px rgba(0,0,0,.5);transform:scale(.94) translateY(16px);transition:transform .3s cubic-bezier(.34,1.56,.64,1);position:relative}
.modal-overlay.active .modal{transform:scale(1) translateY(0)}
.modal-inner{display:grid;grid-template-columns:1fr 1fr}
.modal-img{overflow:hidden;border-radius:var(--r-xl) 0 0 var(--r-xl);background:var(--bg3);display:flex;align-items:center;justify-content:center;font-size:5rem;color:var(--muted)}
.modal-img img{width:100%;height:100%;object-fit:cover}
.modal-content{padding:36px;display:flex;flex-direction:column;justify-content:space-between}
.modal-close{position:absolute;top:14px;right:14px;width:36px;height:36px;border-radius:var(--r-sm);background:var(--bg3);border:none;color:var(--text2);cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:.95rem;transition:all var(--tr)}
.modal-close:hover{background:var(--accent);color:#fff}
.modal-cat{font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:.12em;color:var(--accent);margin-bottom:8px}
.modal-name{font-size:1.7rem;margin-bottom:14px}
.modal-price-main{font-family:var(--font-heading);font-size:2rem;color:var(--accent);font-weight:700}
.modal-price-usd{font-size:.9rem;color:var(--muted);margin-top:2px;margin-bottom:20px}
.modal-row{display:flex;gap:10px;font-size:.88rem;margin-bottom:10px}
.modal-lbl{color:var(--muted);min-width:80px;flex-shrink:0}
.modal-val{color:var(--text);font-weight:500;line-height:1.55}

/* ── ABOUT GRID ──────────────────────────────────────────────── */
.about-grid{display:grid;grid-template-columns:1fr 1fr;gap:72px;align-items:center}
.feat-item{display:flex;gap:14px;align-items:flex-start}
.feat-icon{width:44px;height:44px;border-radius:var(--r-sm);background:var(--accent-glow);color:var(--accent);display:flex;align-items:center;justify-content:center;font-size:1.1rem;flex-shrink:0}
.feat-icon img{width:28px;height:28px;object-fit:contain;border-radius:4px}
.feat-title{font-size:.92rem;font-weight:600;margin-bottom:3px}
.feat-desc{font-size:.83rem;color:var(--muted);line-height:1.55}

/* ── MAPEL / SUBJECT ─────────────────────────────────────────── */
.mapel-hero{background:var(--grad-hero);padding:calc(var(--nav-h) + 56px) 0 56px;text-align:center;border-bottom:1px solid var(--border)}
.mapel-icon-wrap{width:72px;height:72px;border-radius:var(--r-lg);background:var(--grad-accent);color:#fff;display:inline-flex;align-items:center;justify-content:center;font-size:2rem;margin-bottom:20px;box-shadow:0 10px 36px var(--accent-glow)}
.mapel-icon-wrap img{width:44px;height:44px;object-fit:contain;border-radius:var(--r-sm)}
.subject-card{background:var(--bg2);border-radius:var(--r-lg);border:1px solid var(--border);padding:28px;transition:all var(--tr)}
.subject-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-md);border-color:var(--accent)}
.subject-level{display:inline-block;padding:4px 12px;border-radius:100px;font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.1em;background:var(--accent-glow);color:var(--accent);margin-bottom:14px}
.subject-title{font-size:1.25rem;margin-bottom:10px}
.subject-price{font-family:var(--font-heading);font-size:1.5rem;font-weight:700;color:var(--accent)}
.teacher-card{background:var(--bg2);border-radius:var(--r-xl);border:1px solid var(--border);padding:36px;display:flex;gap:28px;align-items:flex-start;box-shadow:var(--shadow-md);margin-bottom:48px}
.teacher-photo{width:130px;height:130px;border-radius:var(--r-lg);overflow:hidden;flex-shrink:0;border:3px solid var(--accent-glow);background:var(--bg3);display:flex;align-items:center;justify-content:center;font-size:2.8rem;color:var(--muted)}
.teacher-photo img{width:100%;height:100%;object-fit:cover}
.teacher-tag{display:inline-flex;align-items:center;gap:7px;font-size:.75rem;font-weight:700;text-transform:uppercase;background:var(--accent);color:#fff;padding:3px 12px;border-radius:100px;margin-bottom:8px}
.teacher-tag img{width:18px;height:18px;object-fit:contain;border-radius:3px;filter:brightness(0) invert(1)}

/* ── PAGE HERO (inner) ───────────────────────────────────────── */
.page-hero{background:var(--grad-hero);padding:calc(var(--nav-h) + 52px) 0 52px;text-align:center;border-bottom:1px solid var(--border)}
.page-hero h1{font-size:clamp(2rem,4.5vw,2.9rem);margin-bottom:10px}
.page-hero p{font-size:1rem;color:var(--muted);max-width:480px;margin:0 auto}
.breadcrumb{display:flex;align-items:center;gap:7px;justify-content:center;margin-bottom:18px;font-size:.8rem;color:var(--muted)}
.breadcrumb a{color:var(--accent)}
.breadcrumb i{font-size:.6rem}

/* ── CONTACT FORM ────────────────────────────────────────────── */
.kontak-grid{display:grid;grid-template-columns:1fr 1fr;gap:44px}
.kontak-item{display:flex;gap:14px;align-items:flex-start}
.kontak-icon{width:46px;height:46px;border-radius:var(--r-sm);background:var(--grad-accent);color:#fff;display:flex;align-items:center;justify-content:center;font-size:1rem;flex-shrink:0}
.kontak-lbl{font-size:.75rem;color:var(--muted);font-weight:700;text-transform:uppercase;letter-spacing:.1em;margin-bottom:3px}
.kontak-val{font-size:.95rem;color:var(--text);font-weight:500}
.form-group{margin-bottom:16px}
.form-label{display:block;font-size:.83rem;font-weight:600;color:var(--text2);margin-bottom:6px}
.form-control{width:100%;padding:11px 14px;background:var(--bg3);border:1.5px solid var(--border);border-radius:var(--r-sm);font-family:var(--font-body);font-size:.9rem;color:var(--text);transition:all var(--tr)}
.form-control:focus{outline:none;border-color:var(--accent);background:var(--bg2);box-shadow:0 0 0 3px var(--accent-glow)}
textarea.form-control{resize:vertical;min-height:120px}
.captcha-box{display:flex;align-items:center;gap:12px;background:var(--bg3);border:1.5px solid var(--border);border-radius:var(--r-sm);padding:12px 16px}
.captcha-question{font-size:.95rem;font-weight:700;color:var(--text);white-space:nowrap}
.captcha-input{width:90px;padding:8px 12px;border-radius:var(--r-sm);border:1.5px solid var(--border);background:var(--bg2);font-family:var(--font-body);font-size:.95rem;color:var(--text);text-align:center}
.captcha-input:focus{outline:none;border-color:var(--accent)}

/* ── ALERTS ──────────────────────────────────────────────────── */
.alert{padding:12px 18px;border-radius:var(--r-sm);margin-bottom:18px;font-size:.88rem;display:flex;align-items:center;gap:9px}
.alert-success{background:rgba(34,197,94,.1);border:1px solid rgba(34,197,94,.3);color:#16a34a}
.alert-danger{background:rgba(239,68,68,.1);border:1px solid rgba(239,68,68,.3);color:#dc2626}

/* ── FOOTER ──────────────────────────────────────────────────── */
.footer{background:var(--bg2);border-top:1px solid var(--border);padding:56px 0 28px}
.footer-inner{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:40px;margin-bottom:36px}
.footer-brand-logo{font-family:var(--font-heading);font-size:1.4rem;font-weight:700;margin-bottom:10px}
.footer-tagline{font-size:.88rem;color:var(--muted);max-width:220px;line-height:1.6}
.footer-heading{font-size:.73rem;font-weight:700;text-transform:uppercase;letter-spacing:.14em;color:var(--muted);margin-bottom:14px}
.footer-links{display:flex;flex-direction:column;gap:9px}
.footer-links a{font-size:.88rem;color:var(--text2);transition:color var(--tr)}
.footer-links a:hover{color:var(--accent)}
.footer-bottom{display:flex;align-items:center;justify-content:space-between;padding-top:22px;border-top:1px solid var(--border);font-size:.82rem;color:var(--muted)}
.footer-social{display:flex;gap:8px}
.footer-social a{width:36px;height:36px;border-radius:var(--r-sm);background:var(--bg3);border:1px solid var(--border);color:var(--muted);display:flex;align-items:center;justify-content:center;transition:all var(--tr);font-size:.88rem}
.footer-social a:hover{background:var(--accent);color:#fff;border-color:var(--accent)}

/* ── SCROLL TOP ──────────────────────────────────────────────── */
.scroll-top{position:fixed;bottom:26px;right:26px;z-index:900;width:44px;height:44px;border-radius:var(--r-md);background:var(--grad-accent);color:#fff;border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;box-shadow:var(--shadow-md);opacity:0;transform:translateY(14px);transition:all var(--tr);pointer-events:none}
.scroll-top.visible{opacity:1;transform:translateY(0);pointer-events:auto}
.scroll-top:hover{transform:translateY(-3px)}

/* ── ANIMATIONS ──────────────────────────────────────────────── */
@keyframes pulse-dot{0%,100%{opacity:1;transform:scale(1)}50%{opacity:.5;transform:scale(1.5)}}
@keyframes fadeInUp{from{opacity:0;transform:translateY(28px)}to{opacity:1;transform:translateY(0)}}
.fade-in-up{animation:fadeInUp .7s ease forwards}
.d1{animation-delay:.1s}.d2{animation-delay:.2s}.d3{animation-delay:.3s}.d4{animation-delay:.4s}

/* ── RESPONSIVE ──────────────────────────────────────────────── */
@media(max-width:1024px){
  .hero-inner{grid-template-columns:1fr;gap:40px}
  .hero-carousel{grid-template-columns:repeat(2,1fr)}
  .footer-inner{grid-template-columns:1fr 1fr}
  .about-grid{grid-template-columns:1fr}
}
@media(max-width:768px){
  .nav-links{display:none}.hamburger{display:flex}
  .kontak-grid{grid-template-columns:1fr}
  section{padding:60px 0}
  .modal-inner{grid-template-columns:1fr}
  .modal-img{border-radius:var(--r-xl) var(--r-xl) 0 0;aspect-ratio:16/9}
  .teacher-card{flex-direction:column}
  .footer-inner{grid-template-columns:1fr;gap:28px}
  .footer-bottom{flex-direction:column;gap:12px;text-align:center}
  .hero-carousel-wrap{display:none}
}
@media(max-width:480px){
  .paintings-grid{grid-template-columns:repeat(auto-fill,minmax(155px,1fr));gap:12px}
  .hero-stats{gap:16px}
  .hero-stat-value{font-size:1.5rem}
}

/* ── PAINTING DETAIL PAGE ──────────────────────────────────────── */
.detail-grid{display:grid;grid-template-columns:1fr 1fr;gap:56px;align-items:start}

.detail-img-col{position:sticky;top:calc(var(--nav-h) + 24px)}
.detail-img-wrap{border-radius:var(--r-xl);overflow:hidden;position:relative;background:var(--bg3);box-shadow:var(--shadow-lg)}
.detail-img-wrap.portrait {aspect-ratio:3/4}
.detail-img-wrap.landscape{aspect-ratio:4/3}
.detail-img-wrap.square   {aspect-ratio:1/1}
.detail-main-img{width:100%;height:100%;object-fit:cover;display:block}
.detail-img-placeholder{width:100%;height:100%;min-height:320px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;color:var(--muted)}
.detail-img-placeholder i{font-size:4rem;opacity:.3}
.detail-img-placeholder p{font-size:.9rem}
.detail-status-badge{position:absolute;top:14px;left:14px;display:inline-flex;align-items:center;gap:6px;background:rgba(0,0,0,.55);backdrop-filter:blur(8px);color:#fff;font-size:.78rem;font-weight:700;padding:5px 13px;border-radius:100px}
.detail-status-badge.sold{background:rgba(107,114,128,.7)}

.detail-cat-tag{display:inline-flex;align-items:center;gap:6px;font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:var(--accent);background:var(--accent-glow);padding:5px 14px;border-radius:100px;margin-bottom:14px;text-decoration:none;transition:all var(--tr)}
.detail-cat-tag:hover{background:var(--accent);color:#fff}

.detail-title{font-size:clamp(1.8rem,3.5vw,2.6rem);margin-bottom:20px;line-height:1.15}

.detail-price-block{margin-bottom:22px}
.detail-price-idr{font-family:var(--font-heading);font-size:2.4rem;font-weight:700;color:var(--accent);line-height:1}
.detail-price-usd{font-size:.92rem;color:var(--muted);margin-top:6px}

.detail-info-rows{display:flex;flex-direction:column;gap:0;margin-bottom:22px;border:1px solid var(--border);border-radius:var(--r-md);overflow:hidden}
.detail-info-row{display:flex;align-items:center;padding:11px 16px;border-bottom:1px solid var(--border);font-size:.9rem}
.detail-info-row:last-child{border-bottom:none}
.dil{color:var(--muted);min-width:130px;display:flex;align-items:center;gap:7px;font-size:.85rem}
.div{color:var(--text);font-weight:500}

.detail-desc-box{background:var(--bg3);border-left:3px solid var(--accent);border-radius:0 var(--r-sm) var(--r-sm) 0;padding:16px 20px;margin-bottom:26px}
.detail-desc-label{font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:var(--accent);margin-bottom:8px}
.detail-desc-text{font-size:.92rem;color:var(--text2);line-height:1.75}

.detail-actions{display:flex;flex-direction:column;gap:10px;margin-bottom:20px}

.btn-wa-order{display:flex;align-items:center;justify-content:center;gap:10px;width:100%;padding:15px 24px;background:linear-gradient(135deg,#25d366,#128c7e);color:#fff;border-radius:var(--r-md);font-family:var(--font-body);font-size:1rem;font-weight:700;text-decoration:none;transition:all var(--tr);border:none;cursor:pointer}
.btn-wa-order:hover{transform:translateY(-2px);box-shadow:0 8px 28px rgba(37,211,102,.35);color:#fff}
.btn-wa-order i{font-size:1.2rem}

.detail-sold-notice{background:rgba(107,114,128,.1);border:1px solid rgba(107,114,128,.25);border-radius:var(--r-sm);padding:12px 16px;font-size:.875rem;color:var(--muted);display:flex;align-items:center;gap:8px}

.detail-share-row{display:flex;align-items:center;gap:8px;padding-top:16px;border-top:1px solid var(--border)}
.detail-share-btn{width:34px;height:34px;border-radius:var(--r-sm);background:var(--bg3);border:1px solid var(--border);color:var(--muted);display:flex;align-items:center;justify-content:center;font-size:.85rem;cursor:pointer;transition:all var(--tr);text-decoration:none}
.detail-share-btn:hover{background:var(--accent);color:#fff;border-color:var(--accent)}

@media(max-width:900px){
  .detail-grid{grid-template-columns:1fr}
  .detail-img-col{position:static}
  .detail-img-wrap.portrait{aspect-ratio:3/4;max-height:420px}
  .detail-img-wrap.landscape{aspect-ratio:4/3}
}
@media(max-width:480px){
  .detail-price-idr{font-size:1.9rem}
  .detail-img-wrap.portrait{max-height:360px}
}

/* ── WHATSAPP FLOATING BUTTON ──────────────────────────────────── */
.wa-float{
  position:fixed;bottom:84px;right:26px;z-index:899;
  width:52px;height:52px;border-radius:50%;
  background:linear-gradient(135deg,#25d366,#128c7e);
  color:#fff;display:flex;align-items:center;justify-content:center;
  font-size:1.5rem;box-shadow:0 4px 20px rgba(37,211,102,.5);
  text-decoration:none;transition:all .25s ease;
  animation:wa-pulse 2.5s ease infinite;
}
.wa-float:hover{transform:scale(1.12);box-shadow:0 8px 32px rgba(37,211,102,.6);color:#fff}
@keyframes wa-pulse{
  0%,100%{box-shadow:0 4px 20px rgba(37,211,102,.5)}
  50%{box-shadow:0 4px 30px rgba(37,211,102,.8),0 0 0 8px rgba(37,211,102,.12)}
}
.wa-float-tooltip{
  position:absolute;right:60px;top:50%;transform:translateY(-50%);
  background:rgba(0,0,0,.75);color:#fff;font-size:.78rem;font-weight:600;
  padding:5px 11px;border-radius:6px;white-space:nowrap;
  opacity:0;pointer-events:none;transition:opacity .2s;
}
.wa-float:hover .wa-float-tooltip{opacity:1}

/* ── DUAL CONTACT BUTTONS (WA + Email) ─────────────────────────── */
.dual-contact{display:flex;flex-direction:column;gap:10px;width:100%}
.btn-wa{
  display:flex;align-items:center;justify-content:center;gap:10px;
  padding:14px 22px;background:linear-gradient(135deg,#25d366,#128c7e);
  color:#fff;border-radius:var(--r-md);font-family:var(--font-body);
  font-size:.95rem;font-weight:700;text-decoration:none;
  transition:all .25s ease;border:none;cursor:pointer;width:100%
}
.btn-wa:hover{transform:translateY(-2px);box-shadow:0 8px 24px rgba(37,211,102,.4);color:#fff}
.btn-wa i{font-size:1.15rem}
.btn-wa-secondary{
  display:flex;align-items:center;justify-content:center;gap:10px;
  padding:13px 22px;background:transparent;
  border:2px solid #25d366;color:#128c7e;border-radius:var(--r-md);
  font-family:var(--font-body);font-size:.9rem;font-weight:600;
  text-decoration:none;transition:all .25s ease;cursor:pointer;width:100%
}
[data-theme="dark"] .btn-wa-secondary{color:#25d366}
.btn-wa-secondary:hover{background:rgba(37,211,102,.1);transform:translateY(-1px)}

/* ── PAINTING CARD WA QUICK BUTTON ────────────────────────────── */
.painting-card .p-wa-btn{
  position:absolute;bottom:10px;right:10px;
  width:38px;height:38px;border-radius:50%;
  background:linear-gradient(135deg,#25d366,#128c7e);
  color:#fff;display:flex;align-items:center;justify-content:center;
  font-size:.95rem;text-decoration:none;
  box-shadow:0 3px 12px rgba(37,211,102,.5);
  transition:all .25s ease;opacity:0;transform:scale(.8)
}
.painting-card:hover .p-wa-btn{opacity:1;transform:scale(1)}
.painting-card .p-wa-btn:hover{transform:scale(1.15)!important}

/* ═══════════════════════════════════════════════════
   BANNER SLIDER — COMPACT ELEGANT CARD
═══════════════════════════════════════════════════ */

/* ── outer section: subtle background, vertical breathing room ── */
.banner-section {
  width: 100%;
  position: relative;
  padding: 0;
  background: transparent;
}

/* ── Banner di atas (top) — fullwidth, langsung setelah navbar ── */
.banner-top {
  margin-top: 0;
}
.banner-top .banner-container-full {
  width: 100%;
  padding: 0;
}
.banner-top .banner-slider {
  border-radius: 0;
  box-shadow: 0 8px 40px rgba(0,0,0,.22);
  max-height: 520px;
  aspect-ratio: 21 / 8;
}
.banner-top .banner-img {
  border-radius: 0;
}
.banner-top .banner-link {
  border-radius: 0;
}
.banner-top .banner-caption {
  border-radius: 0;
  padding: clamp(20px,5vw,56px) clamp(24px,6vw,80px);
}
.banner-top .banner-caption-title {
  font-size: clamp(1.3rem, 3.5vw, 2.6rem);
  text-shadow: 0 3px 20px rgba(0,0,0,.6);
}
.banner-top .banner-caption-sub {
  font-size: clamp(.85rem, 1.8vw, 1.1rem);
  text-shadow: 0 2px 10px rgba(0,0,0,.55);
  margin-top: 6px;
}
.banner-top .banner-arrow {
  width: 48px;
  height: 48px;
  font-size: 1rem;
  background: rgba(0,0,0,.28);
  border-color: rgba(255,255,255,.25);
}
.banner-top .banner-prev { left: 24px; }
.banner-top .banner-next { right: 24px; }
.banner-top .banner-dots { bottom: 18px; }
.banner-top .banner-dot { width: 9px; height: 9px; }
.banner-top .banner-dot.active { width: 32px; }

/* ── centred wrapper (dipakai untuk banner di bawah / lama) ── */
.banner-container {
  max-width: 820px;
  margin: 0 auto;
  padding: 0 32px;
}
.banner-container-full {
  width: 100%;
  max-width: 100%;
}

/* ── the slider card itself ── */
.banner-slider {
  position: relative;
  width: 100%;
  overflow: hidden;
  border-radius: 18px;
  box-shadow:
    0 4px 6px rgba(0,0,0,.07),
    0 12px 32px rgba(0,0,0,.16),
    0 2px 0 rgba(255,255,255,.06) inset;
  background: #111;
  aspect-ratio: 16 / 7;
  min-height: 120px;
  max-height: 380px;
  cursor: pointer;
}

/* ── individual slides ── */
.banner-slide {
  position: absolute;
  inset: 0;
  opacity: 0;
  transition: opacity .65s cubic-bezier(.4,0,.2,1);
  pointer-events: none;
}
.banner-slide.active {
  opacity: 1;
  position: relative;
  pointer-events: auto;
}

/* ── image fills the card fully, cropped to fit ── */
.banner-img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
  display: block;
  border-radius: 18px;
  transition: transform 6s ease;
}
.banner-slide.active .banner-img {
  transform: scale(1.03);    /* subtle Ken Burns */
}

/* ── clickable link overlay ── */
.banner-link {
  display: block;
  position: absolute;
  inset: 0;
  z-index: 2;
  border-radius: 18px;
}

/* ── gradient + caption ── */
.banner-caption {
  position: absolute;
  bottom: 0; left: 0; right: 0;
  padding: clamp(16px, 3.5vw, 28px) clamp(18px, 4vw, 30px);
  background: linear-gradient(
    to top,
    rgba(0,0,0,.72) 0%,
    rgba(0,0,0,.28) 55%,
    transparent 100%
  );
  border-radius: 0 0 18px 18px;
  z-index: 3;
  pointer-events: none;
}
.banner-caption-title {
  font-family: var(--font-heading, Georgia, serif);
  font-size: clamp(1rem, 2.4vw, 1.65rem);
  font-weight: 700;
  color: #fff;
  margin: 0 0 5px;
  line-height: 1.2;
  text-shadow: 0 2px 12px rgba(0,0,0,.5);
  letter-spacing: -.01em;
}
.banner-caption-sub {
  font-size: clamp(.74rem, 1.4vw, .92rem);
  color: rgba(255,255,255,.9);
  margin: 0;
  text-shadow: 0 1px 6px rgba(0,0,0,.5);
}

/* ── navigation arrows — outside the card on desktop ── */
.banner-arrow {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  z-index: 20;
  width: 38px;
  height: 38px;
  border-radius: 50%;
  /* Glass pill */
  background: rgba(255,255,255,.15);
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
  border: 1.5px solid rgba(255,255,255,.30);
  color: #fff;
  font-size: .88rem;
  cursor: pointer;
  transition: background .18s, transform .18s, border-color .18s;
  display: flex;
  align-items: center;
  justify-content: center;
  box-shadow: 0 2px 10px rgba(0,0,0,.22);
}
.banner-arrow:hover {
  background: rgba(255,255,255,.32);
  border-color: rgba(255,255,255,.55);
  transform: translateY(-50%) scale(1.1);
}
/* Push arrows inside the card edges */
.banner-prev { left: 14px; }
.banner-next { right: 14px; }

/* ── indicator dots ── */
.banner-dots {
  position: absolute;
  bottom: 12px;
  left: 50%;
  transform: translateX(-50%);
  display: flex;
  gap: 6px;
  z-index: 20;
  align-items: center;
}
.banner-dot {
  width: 7px;
  height: 7px;
  border-radius: 50%;
  background: rgba(255,255,255,.4);
  border: 1.5px solid rgba(255,255,255,.65);
  cursor: pointer;
  padding: 0;
  transition: background .25s, width .3s cubic-bezier(.4,0,.2,1), border-color .25s;
  flex-shrink: 0;
}
.banner-dot.active {
  background: #fff;
  width: 24px;
  border-radius: 4px;
  border-color: #fff;
}
.banner-dot:hover:not(.active) {
  background: rgba(255,255,255,.75);
  transform: scale(1.15);
}

/* ────────────────────────
   RESPONSIVE BREAKPOINTS
──────────────────────── */

/* Tablet (≤ 900px) */
@media (max-width: 900px) {
  .banner-section   { padding: 0; }
  .banner-container { padding: 0 20px; max-width: 100%; }
  .banner-slider    { aspect-ratio: 16 / 7; max-height: 300px; border-radius: 12px; }
  .banner-img       { border-radius: 12px; }
  .banner-link      { border-radius: 12px; }
  .banner-caption   { border-radius: 0 0 12px 12px; }
  /* top banner stays edge-to-edge on tablet too */
  .banner-top .banner-slider { border-radius: 0; aspect-ratio: 16/6; max-height: 340px; }
  .banner-top .banner-img, .banner-top .banner-link { border-radius: 0; }
  .banner-top .banner-arrow { width: 40px; height: 40px; }
  .banner-top .banner-prev  { left: 16px; }
  .banner-top .banner-next  { right: 16px; }
}

/* Mobile (≤ 580px) */
@media (max-width: 580px) {
  .banner-section   { padding: 0; }
  .banner-container { padding: 0 14px; }
  .banner-slider    { aspect-ratio: 3 / 2; max-height: 220px; border-radius: 10px; }
  .banner-img       { border-radius: 10px; }
  .banner-link      { border-radius: 10px; }
  .banner-caption   { border-radius: 0 0 10px 10px; padding: 12px 14px; }
  .banner-arrow     { width: 32px; height: 32px; font-size: .78rem; }
  .banner-prev      { left: 9px; }
  .banner-next      { right: 9px; }
  .banner-dots      { bottom: 9px; }
  /* top banner mobile */
  .banner-top .banner-slider { aspect-ratio: 16/9; max-height: 260px; }
  .banner-top .banner-arrow  { width: 34px; height: 34px; }
  .banner-top .banner-prev   { left: 10px; }
  .banner-top .banner-next   { right: 10px; }
  .banner-top .banner-caption-title { font-size: 1.1rem; }
}

/* Very small phones (≤ 380px) */
@media (max-width: 380px) {
  .banner-container { padding: 0 10px; }
  .banner-slider    { aspect-ratio: 4 / 3; }
  .banner-arrow     { display: none; }   /* swipe only on tiny screens */
}

/* ═══════════════════════════════════════════════════
   PAINTINGS GRID — UNIFORM SIZE FIX


   Portrait cards: all same height
   Landscape cards: wider but same row height
═══════════════════════════════════════════════════ */
.paintings-grid-uniform {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(220px, 1fr));
  gap: 22px;
  align-items: start; /* prevent stretch */
}
/* Remove old landscape span override for uniform grid */
.paintings-grid-uniform .painting-card-uniform {
  background: var(--bg2);
  border-radius: var(--r-lg);
  border: 1px solid var(--border);
  overflow: hidden;
  box-shadow: var(--shadow-sm);
  transition: all var(--tr);
  cursor: pointer;
}
.paintings-grid-uniform .painting-card-uniform:hover {
  transform: translateY(-6px);
  box-shadow: var(--shadow-lg);
}
/* Uniform image container: fixed height, image fits inside without crop */
.painting-img-uniform {
  position: relative;
  overflow: hidden;
  background: var(--bg3);
  /* Portrait: taller box */
  width: 100%;
  aspect-ratio: 3 / 4;
  display: flex;
  align-items: center;
  justify-content: center;
}
.painting-img-uniform.landscape {
  /* Landscape: shorter but still 3/4 box, image fits inside */
  aspect-ratio: 3 / 4;
}
.painting-img-uniform.square {
  aspect-ratio: 3 / 4;
}
.painting-img-uniform img {
  /* Key: contain so no crop, centred, fills as much as possible */
  width: 100%;
  height: 100%;
  object-fit: contain;
  object-position: center;
  transition: transform .5s ease;
  background: var(--bg3);
}
.painting-card-uniform:hover .painting-img-uniform img {
  transform: scale(1.04);
}
/* Overlay reuse existing styles */
.painting-img-uniform .painting-overlay {
  position: absolute;
  inset: 0;
  background: rgba(0,0,0,.45);
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 12px;
  opacity: 0;
  transition: opacity .3s;
}
.painting-card-uniform:hover .painting-img-uniform .painting-overlay { opacity: 1; }
.painting-img-uniform .painting-badge {
  position: absolute;
  top: 10px; left: 10px;
  background: var(--accent);
  color: #fff;
  font-size: .68rem;
  font-weight: 700;
  padding: 3px 10px;
  border-radius: 20px;
  letter-spacing: .04em;
  text-transform: uppercase;
}
.painting-img-uniform .painting-badge.sold {
  background: rgba(0,0,0,.5);
}

/* Mobile adjustments */
@media (max-width: 600px) {
  .paintings-grid-uniform {
    grid-template-columns: repeat(2, 1fr);
    gap: 12px;
  }
}

/* ═══════════════════════════════════════════════════
   LOGO IMAGE in navbar & footer
═══════════════════════════════════════════════════ */
.nav-logo-img {
  width: 30px;
  height: 30px;
  object-fit: contain;
  border-radius: 6px;
  display: inline-block;
  vertical-align: middle;
}
.footer-logo-img {
  width: 26px;
  height: 26px;
  object-fit: contain;
  border-radius: 5px;
  display: inline-block;
  vertical-align: middle;
}
