* { margin: 0; padding: 0; box-sizing: border-box; }
:root { --bg: #e4dacb; --panel: #f5f1e8; --panel-2: #ede7da; --text: #2f5234; --text-soft: #5f6f58; --line: rgba(47,82,52,.16); --shadow: 0 14px 40px rgba(47,82,52,.08); --radius-xl: 24px; --radius-lg: 18px; }
html, body { width: 100%; min-height: 100%; }
body { background: var(--bg); color: var(--text); font-family: 'Montserrat', Arial, sans-serif; }
body.modal-open { overflow: hidden; }
.background-marble { position: fixed; inset: 0; z-index: 0; pointer-events:none; background: radial-gradient(rgba(0,0,0,.035) 1px, transparent 1px), radial-gradient(rgba(0,0,0,.025) 1px, transparent 1px), radial-gradient(rgba(255,255,255,.08) 1px, transparent 1px); background-size: 6px 6px, 8px 8px, 10px 10px; background-position: 0 0, 3px 3px, 5px 2px; }
.intro { position: fixed; inset: 0; z-index: 30; display:flex; align-items:center; justify-content:center; background: rgba(228,218,203,.92); }
.intro.hide { opacity: 0; transition: opacity .45s ease; pointer-events:none; }
.intro-content { display:flex; flex-direction:column; align-items:center; gap: 14px; }
.reveal { opacity:0; clip-path: polygon(0 0,0 0,0 100%,0 100%); }
.logo-reveal { animation: revealIn .7s forwards, revealOut .55s forwards; animation-delay:0s,1.12s; }
.text-reveal { animation: revealIn .7s forwards, revealOut .55s forwards; animation-delay:.08s,1.2s; }
@keyframes revealIn { from { opacity:0; clip-path: polygon(0 0,0 0,0 100%,0 100%);} to { opacity:1; clip-path: polygon(0 0,100% 0,100% 100%,0 100%);} }
@keyframes revealOut { from { opacity:1; clip-path: polygon(0 0,100% 0,100% 100%,0 100%);} to { opacity:0; clip-path: polygon(100% 0,100% 0,100% 100%,100% 100%);} }
.logo-intro { width: 210px; display:block; }
.tagline, .nav a, .hero h1, h1, h2, h3, .btn, .eyebrow, .admin-fab, .section-link, .field span { font-family:'Oswald', 'Montserrat', sans-serif; }
.tagline { font-size: clamp(1.2rem, 2vw, 1.65rem); color: var(--text); text-transform: uppercase; text-align:center; letter-spacing:.02em; }
.topbar { z-index: 10 !important; position: sticky; top:0; z-index:20; opacity:0; transform:translateY(-10px); transition: opacity .55s ease, transform .55s ease; border-bottom:1px solid var(--line); background: rgba(228,218,203,.94); backdrop-filter: blur(10px); }
.topbar.show { opacity:1; transform:translateY(0); }
.topbar-inner { max-width:1580px; margin:0 auto; padding:16px 28px; display:grid; grid-template-columns:1fr auto 1fr; align-items:center; gap:28px; }
.logo-center-link { display:inline-flex; justify-content:center; align-items:center; }
.logo-center { width: 120px; display:block; }
.nav { display:flex; align-items:center; gap:28px; }
.nav-left { justify-content:flex-end; } .nav-right { justify-content:flex-start; }
.nav a { font-size: 1rem; text-decoration:none; color: var(--text); text-transform:uppercase; white-space:nowrap; position:relative; }
.nav a::after { content:''; position:absolute; left:0; bottom:-6px; width:0; height:1px; background:var(--text); transition: width .25s ease; }
.nav a:hover::after, .nav a:focus-visible::after { width:100%; }
.page-shell { position:relative; max-width:1580px; margin:0 auto; padding:28px 28px 90px; }
.hero, .category-preview, .admin-block, .editor-card, .auth-card, .detail-head-box, .detail-media-box, .listing-head { background: rgba(245,241,232,.95); border:1px solid var(--line); border-radius: var(--radius-xl); box-shadow: var(--shadow); }
.hero { padding:36px; margin-top:14px; }
.hero h1 { font-size: clamp(2rem,4vw,3.6rem); line-height:1; max-width:850px; }
.hero-text { max-width:780px; color:var(--text-soft); font-size:1.05rem; margin-top:12px; line-height:1.6; }
.eyebrow { text-transform:uppercase; font-size:.88rem; color:var(--text-soft); margin-bottom:8px; }
.home-placeholder { margin-top: 28px; }
.section-grid, .admin-sections { display:grid; gap:26px; margin-top:28px; }
.category-preview, .admin-block, .listing-head { padding:26px; }
.auth-wrap { min-height: calc(100vh - 180px); display:grid; place-items:center; }
.auth-card { width:min(560px,100%); padding:30px; }
.editor-card { padding:26px; margin-top:16px; }
.admin-head, .section-title-row { display:flex; align-items:center; justify-content:space-between; gap:16px; }
.admin-head { margin-top:16px; margin-bottom:20px; }
.admin-login h1 { color: #7f2d2d; }
.admin-login p { color: #7f2d2d; }
.admin-login .btn-primary { background: #7f2d2d; color: white; }
.admin-login .btn-primary:hover { background: #f74f4f; }
h1 { font-size: clamp(2rem,3vw,3rem); line-height:1; }
h2 { font-size:1.5rem; }
h3 { font-size:1.22rem; line-height:1.1; }
.muted { color:var(--text-soft); line-height:1.6; margin-top:10px; }
.card-grid { display:grid; grid-template-columns: repeat(auto-fit, minmax(240px, 1fr)); gap:22px; margin-top:18px; }
.compact-grid { grid-template-columns: repeat(auto-fit, minmax(220px, 260px)); justify-content:flex-start; }
.card { display:flex; flex-direction:column; text-decoration:none; color:inherit; background: rgba(255,255,255,.42); border:1px solid var(--line); border-radius:22px; overflow:hidden; transition: transform .2s ease, box-shadow .2s ease; box-shadow: 0 8px 28px rgba(47,82,52,.06); }
.card:hover { transform: translateY(-3px); box-shadow: 0 12px 34px rgba(47,82,52,.1); }
.card-media { background: var(--panel-2); overflow:hidden; }
.ratio-poster-small { aspect-ratio: 1350 / 1688; max-height: 300px; }
.ratio-video-small { aspect-ratio: 16 / 9; display:grid; place-items:center; max-height: 180px; }
.card-media img, .detail-media-box img { width:100%; height:100%; display:block; object-fit:cover; }
.video-thumb { width:86px; height:86px; border-radius:999px; display:grid; place-items:center; background: var(--text); color:white; font-size:2rem; box-shadow: var(--shadow); }
.video-thumb.small { width:68px; height:68px; font-size:1.5rem; }
.card-body { padding:16px; display:grid; gap:9px; }
.meta-line, .info-row, .views-line { color: var(--text-soft); line-height:1.5; font-family:'Montserrat', Arial, sans-serif; }
.detail-wrap { display:grid; gap:22px; margin-top:16px; }
.detail-head-box { padding:28px; }
.detail-head-box h1 { margin-bottom:14px; }
.detail-media-box { overflow:hidden; }
.detail-media-box-image {max-width: 780px; width: 100%; margin: 0 auto; overflow: hidden; }
.detail-media-box-image img { width: 100%; height: auto; aspect-ratio: 1350 / 1688; object-fit: cover; display: block; }
.video-box iframe { width:100%; aspect-ratio:16 / 9; border:none; display:block; }
.large-video iframe { min-height: min(72vh, 760px); }
.stack-form { display:grid; gap:18px; margin-top:18px; }
.field { display:grid; gap:8px; }
input[type='text'], input[type='password'], input[type='datetime-local'], input[type='file'] { width:100%; border:1px solid var(--line); background: rgba(255,255,255,.38); border-radius:16px; padding:14px 16px; font-size:1rem; color:var(--text); font-family:'Montserrat', Arial, sans-serif; }
.preview-block { background: rgba(255,255,255,.34); border:1px solid var(--line); border-radius:20px; padding:14px; }
.admin-preview-image { width:min(240px,100%); aspect-ratio: 1350 / 1688; object-fit:cover; display:block; margin-top:12px; border-radius:14px; }
.form-actions, .action-row { display:flex; flex-wrap:wrap; gap:10px; align-items:center; }
.admin-table-wrap { overflow-x:auto; margin-top:16px; }
.admin-table { width:100%; border-collapse:collapse; min-width:720px; }
.admin-table th, .admin-table td { padding:14px 12px; border-bottom:1px solid var(--line); text-align:left; vertical-align:middle; font-family:'Montserrat', Arial, sans-serif; }
.btn { border:none; text-decoration:none; display:inline-flex; align-items:center; justify-content:center; gap:8px; border-radius:999px; padding:12px 18px; cursor:pointer; transition:transform .18s ease, opacity .18s ease; }
.btn:hover { transform: translateY(-1px); }
.btn-primary { background: var(--text); color:white; }
.btn-secondary { background: transparent; color: var(--text); border:1px solid var(--line); }
.btn-danger { background:#7f2d2d; color:white; }
.btn-ghost { background: rgba(255,255,255,.34); color: var(--text); border:1px solid var(--line); }
.btn-small { padding:9px 14px; font-size:.92rem; }
.section-link { color: var(--text); text-decoration:none; }
.empty-state, .flash { background: rgba(255,255,255,.45); border:1px solid var(--line); border-radius:18px; padding:16px 18px; color: var(--text-soft); font-family:'Montserrat', Arial, sans-serif; }
.flash { margin-bottom:18px; }
.flash-success { border-color: rgba(47,82,52,.32); }
.flash-error { border-color: rgba(127,45,45,.38); color:#7f2d2d; }
.admin-fab { position: fixed; right:22px; bottom:22px; z-index:25; background: var(--text); color:white; text-decoration:none; border-radius:999px; padding:14px 18px; box-shadow: 0 16px 30px rgba(47,82,52,.22); display:inline-flex; align-items:center; gap:10px; }
.confirm-overlay { position: fixed; inset:0; z-index: 80; display:none; }
.confirm-overlay.open { display:block; }
.confirm-backdrop { position:absolute; inset:0; background: rgba(40,40,40,.56); }
.confirm-box { position:relative; z-index:1; width:min(92vw,560px); margin: 18vh auto 0; background: rgba(245,241,232,.98); border:1px solid var(--line); border-radius: 24px; box-shadow: var(--shadow); padding: 24px; }
.confirm-box p { margin-top: 10px; color: var(--text-soft); font-family:'Montserrat', Arial, sans-serif; line-height:1.6; }
.image-modal { position: fixed; inset:0; z-index: 120; display:none; }
.image-modal.open { display:block; }
.image-modal-backdrop { position:absolute; inset:0; background: rgba(32,32,32,.82); }
.image-modal-content { position:relative; z-index:1; width:min(94vw,1080px); max-height:92vh; margin: 4vh auto; padding:14px; border-radius:24px; background: rgba(245,241,232,.98); box-shadow: var(--shadow); }
.image-modal-content img { width:100%; max-height: calc(92vh - 28px); object-fit: contain; display:block; border-radius:16px; }
.image-modal-close { position:absolute; top:10px; right:14px; border:none; background: rgba(0,0,0,.46); color:white; width:38px; height:38px; border-radius:999px; cursor:pointer; font-size:1.5rem; z-index:2; }
.clickable-media img, .zoomable-image { cursor: zoom-in; }
@media (max-width: 1200px) { .topbar-inner { grid-template-columns:1fr; justify-items:center; } .logo-center-link { order:-1; } .nav { flex-wrap:wrap; justify-content:center; } }
@media (max-width: 768px) { .page-shell { padding:18px 18px 88px; } .hero, .category-preview, .admin-block, .editor-card, .auth-card, .detail-head-box, .detail-media-box, .listing-head { padding:20px; } .logo-intro { width:150px; } .logo-center { width:88px; } .nav a { font-size:.92rem; } .admin-fab { right:14px; bottom:14px; padding:12px 16px; } h1 { font-size:2rem; } .detail-media-box-image { max-width: 100%; } }
.site-footer { margin-top: 28px; padding: 22px 24px; background: rgba(245,241,232,0.92); border: 1px solid var(--line); border-radius: 20px; box-shadow: var(--shadow); color: var(--text-soft); line-height: 1.7; text-align: center; font-size: 0.95rem; }
.confirm-overlay { position: fixed; inset: 0; z-index: 70; display: none; }
.confirm-overlay.open { display: block; }
.confirm-backdrop { position: absolute; inset: 0; background: rgba(40,40,40,0.52); }
.confirm-box { position: relative; z-index: 1; width: min(92vw, 560px); margin: 14vh auto 0; padding: 26px; background: rgba(245,241,232,0.98); border: 1px solid var(--line); border-radius: 24px; box-shadow: var(--shadow); }
.confirm-box p { margin-top: 10px; color: var(--text-soft); line-height: 1.6; }
.cover-grid { grid-template-columns: repeat(auto-fit, minmax(402px, 402px)); justify-content: start; align-items: start; }
.cover-card { text-decoration: none; color: inherit; display: flex; flex-direction: column; width: 402px; border-radius: 24px; overflow: hidden; border: 1px solid var(--line); box-shadow: 0 12px 32px rgba(47,82,52,0.10); background: rgba(245,241,232,0.90); }
.cover-card-media { width: 100%; aspect-ratio: 402 / 251; overflow: hidden; background: var(--panel-2); }
.cover-card-media img { width: 100%; height: 100%; display: block; object-fit: cover; transition: transform .35s ease; }
.cover-card:hover .cover-card-media img { transform: scale(1.04); }
.cover-card-info { padding: 16px 18px 18px; background: linear-gradient(180deg, rgba(245,241,232,0.86), rgba(245,241,232,0.98)); border-top: 1px solid var(--line); }
.cover-card-info h3 { margin-bottom: 8px; }
.cover-card-fallback { width: 100%; height: 100%; display: grid; place-items: center; font-family: "Oswald", Arial, sans-serif; color: var(--text); font-size: 2rem; background: linear-gradient(180deg, rgba(237,231,218,1), rgba(228,218,203,1)); }
.detail-media-box { width: min(900px, 100%); margin: 0 auto; }
.detail-image {width: 100%; height: auto; aspect-ratio: 1350 / 1688; object-fit: cover !important; display: block; }
.image-modal { z-index: 999999; }
.image-modal-content { position: relative; width: min(96vw, 1200px); max-height: 94vh; z-index: 1000000 }
.image-modal-content img { max-height: calc(94vh - 28px); }
a { color: inherit; text-decoration: none; transition: 0.2s; }
a:hover { opacity: 0.7; }
@media (max-width: 768px) { .cover-grid { grid-template-columns: repeat(auto-fit, minmax(402px, 402px)); justify-content: start; align-items: start; }
.cover-grid { grid-template-columns: 1fr; }
.cover-card { width: 100%; }
.cover-card-media { aspect-ratio: 402 / 251; }
.cover-card-info { padding: 14px; } }
.preview-block + .preview-block { margin-top: 12px; }
.bg-video { position: fixed; top: 0; left: 0; width: 100%; height: 100%; object-fit: cover; z-index: -2; }
.overlay { position: fixed; inset: 0; z-index: -1; background: linear-gradient( rgba(0,0,0,0.65), rgba(0,0,0,0.3) ); }
.hero-home { position: relative; z-index: 2; height: 50vh; display: flex; align-items: center; justify-content: center; }
.hero-center { text-align: center; max-width: 900px; padding: 0 20px; }
.hero-home h1 { font-size: clamp(3rem, 6vw, 6rem); color: white; margin-bottom: 20px; text-shadow: rgba(47,82,52,1) 0px 0px 15px; }
.hero-home .hero-text { color: white; font-size: 1.2rem; line-height: 1.6; opacity: 0.9; text-shadow: rgba(47,82,52,1) 0px 0px 15px; }
.hero-center { animation: float 3.2s linear infinite; }
@keyframes float { 0% { transform: translateY(0px); } 25% { transform: translateY(-4px); } 50% { transform: translateY(-8px); } 75% { transform: translateY(-4px); } 100% { transform: translateY(0px); } }