:root {
  --primary: #111827;
  --secondary: #F8F5F0;
  --accent: #C9A227;
  --neutral: #FFFFFF;
  --text: #374151;
  --muted: #6B7280;
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body { font-family: 'Inter', sans-serif; color: var(--text); background: linear-gradient(180deg,#fff 0%,#fffaf6 100%); }
img { max-width:100%; display:block; }
a { text-decoration:none; color:inherit; }
section { padding: 80px 0; }
.text-light-2 { color: rgba(255,255,255,0.82) !important; }
.card-soft, .feature-card, .product-card, .gallery-card, .counter-card { color: var(--primary); }
.card-soft p, .feature-card p, .product-card p, .gallery-card p, .counter-card p { color: #4b5563; }
.bg-dark-custom { background: rgba(17,24,39,.96) !important; backdrop-filter: blur(12px); }
.text-accent { color: var(--accent) !important; }
.bg-accent { background: var(--accent) !important; }
.btn-accent { background: var(--accent); color:#111; border-color:var(--accent); font-weight:600; }
.btn-accent:hover { background:#d3a83a; color:#111; }
.btn-outline { border:1px solid rgba(201,162,39,.4); color:#111; background:transparent; }
.nav-link { color: rgba(255,255,255,.88) !important; font-weight:500; }
.nav-link:hover { color: var(--accent) !important; }
.hero-panel { min-height: 88vh; display:flex; align-items:center; background:
  linear-gradient(120deg, rgba(17,24,39,.86), rgba(17,24,39,.65)),
  url('https://images.unsplash.com/photo-1505693416388-ac5ce068fe85?auto=format&fit=crop&w=1600&q=80') center/cover no-repeat;
}
.hero-badge { border:1px solid rgba(255,255,255,.15); background:rgba(255,255,255,.08); color:#fff; border-radius:999px; padding:8px 14px; display:inline-flex; align-items:center; gap:8px; }
.section-heading h2 { font-size: clamp(2rem, 5vw, 3rem); color:var(--primary); font-weight:800; }
.section-heading p { color:var(--muted); max-width:720px; }
.card-soft { background: var(--neutral); border:1px solid #eee; border-radius: 24px; box-shadow: 0 22px 36px rgba(17,24,39,.08); }
.icon-box { width: 52px; height:52px; border-radius:14px; background: linear-gradient(135deg, #fff, #f3ebda); color: var(--accent); display:grid; place-items:center; box-shadow: inset 0 0 0 1px rgba(201,162,39,.2); }
.feature-card { transition: transform .25s ease, box-shadow .25s ease; }
.feature-card:hover { transform: translateY(-4px); box-shadow: 0 18px 30px rgba(17,24,39,.14); }
.category-card { display:flex; flex-direction:column; }
.category-thumb { width:100%; aspect-ratio: 1 / 1; object-fit:cover; object-position:center; border-radius:18px; background:#f3f4f6; }
.timeline { position:relative; border-left:2px solid #eee; margin-left:12px; }
.timeline-item { position:relative; padding-left:28px; margin-bottom:24px; }
.timeline-item::before { content:""; position:absolute; left:-7px; top:8px; width:12px; height:12px; border-radius:50%; background:var(--accent); box-shadow:0 0 0 4px rgba(201,162,39,.12); }
.counter-card { border-radius: 20px; background: linear-gradient(145deg, #fff, #f8f5f0); border:1px solid #eee; }
.counter-value { font-size: 2rem; font-weight:800; color:var(--primary); }
.product-card img, .gallery-card img, .square-thumb { border-radius:18px; width:100%; aspect-ratio: 1 / 1; object-fit:cover; object-position:center; }

.square-thumb { height: 180px; }
.product-tag { background: rgba(201,162,39,.12); color:#9a7a0c; border-radius:999px; padding:6px 10px; font-size:.78rem; text-transform:uppercase; letter-spacing:.18em; }
.footer { background:#0f172a; color:#fff; }
.footer-links a, .footer-links li { color:#dce4ea; }
.floating-wa, .floating-call, .back-to-top { position:fixed; right:18px; width:56px; height:56px; border-radius:50%; display:grid; place-items:center; box-shadow:0 12px 20px rgba(0,0,0,.18); z-index:1100; background:#25D366; color:#fff; font-size:1.2rem; border:0; }
.floating-wa { bottom:92px; }
.floating-call { bottom:24px; background:#111827; }
.back-to-top { bottom:160px; background:#C9A227; color:#111; display:none; }
.table th, .table td { vertical-align: middle; }
.admin-shell { min-height:100vh; background:linear-gradient(135deg,#111827 0%, #172033 45%, #0b1220 100%); color:#fff; }
.admin-card { border-radius:24px; background: rgba(255,255,255,.06); border:1px solid rgba(255,255,255,.08); box-shadow: 0 22px 36px rgba(0,0,0,.18); padding: 1rem; }
.admin-shell .container { max-width: 1450px; }
.admin-shell h1, .admin-shell h2, .admin-shell h3 { line-height: 1.2; }
.admin-shell .py-4 { padding-top: 1.5rem !important; padding-bottom: 1.5rem !important; }
.admin-shell .mb-4 { margin-bottom: 1.5rem !important; }
.admin-shell .g-4 { --bs-gutter-y: 1.25rem; --bs-gutter-x: 1.25rem; }
.form-label { color:#111827; }
.form-control, .form-select { border-radius:14px; border:1px solid #d1d5db; background:#fff; color:#111827; }
.form-control::placeholder { color:#6b7280; }
.form-control:focus, .form-select:focus { background:#fff; color:#111827; box-shadow:0 0 0 .25rem rgba(201,162,39,.18); border-color:rgba(201,162,39,.45); }
.admin-shell .form-label { color:#e5e7eb; }
.admin-shell .form-control, .admin-shell .form-select,
.admin-shell select.form-select { border:1px solid rgba(255,255,255,.12); background-color: rgba(17,24,39,0.92) !important; color:#fff !important; }
.admin-shell .form-control::placeholder { color:#cbd5e1; }
.admin-shell .form-control:focus, .admin-shell .form-select:focus,
.admin-shell select.form-select:focus { background-color: rgba(17,24,39,0.96) !important; color:#fff !important; box-shadow:0 0 0 .25rem rgba(201,162,39,.18); border-color:rgba(201,162,39,.45); }
.admin-shell .form-select option,
.admin-shell .form-select option:checked { background-color:#111827; color:#fff; }
.admin-shell .form-select { appearance: auto; -webkit-appearance: auto; }
.admin-shell .form-select option,
.admin-shell .form-select option:checked { background-color:#111827; color:#fff; }
.admin-shell .form-select { appearance: auto; -webkit-appearance: auto; }
.badge-soft { background:rgba(201,162,39,.12); color:#ffd56b; }
.page-banner { padding: 64px 0 24px; background: linear-gradient(135deg,#111827,#1f2937); color:#fff; }
.map-card { border-radius:24px; overflow:hidden; border:1px solid #eee; }
@media (max-width: 991px) {
  .hero-panel { min-height: auto; padding: 72px 0 40px; }
  .hero-panel .display-4 { font-size: clamp(2rem, 6vw, 2.8rem); }
  .floating-wa { bottom: 84px; }
  .back-to-top { bottom: 146px; }
}

@media (max-width: 767px) {
  section { padding: 56px 0; }
  .admin-shell .container { padding-left: 14px; padding-right: 14px; }
  .admin-shell .py-4 { padding-top: 1rem !important; padding-bottom: 1rem !important; }
  .admin-card { border-radius: 18px; padding: 0.95rem; }
  .category-thumb { height:150px; }
  .hero-panel { min-height: 84vh; }
  .hero-panel .display-4 { line-height: 1.15; }
  .hero-badge { font-size: .9rem; }
  .section-heading h2 { font-size: clamp(1.5rem, 8vw, 2rem); }
  .card-soft { border-radius: 18px; }
  .product-card img, .gallery-card img { height: 190px; }
  .counter-value { font-size: 1.65rem; }
  .floating-wa, .floating-call, .back-to-top { width: 50px; height: 50px; right: 12px; font-size: 1rem; }
  .floating-wa { bottom: 80px; }
  .floating-call { bottom: 18px; }
  .back-to-top { bottom: 136px; }
}

@media (max-width: 575px) {
  .navbar-brand { font-size: 1rem; }
  .hero-panel { min-height: 88vh; padding-top: 56px; }
  .hero-panel .lead { font-size: 1rem; }
  .btn-lg { width: 100%; }
  .section-heading p { font-size: .95rem; }
  .timeline { border-left-width: 1px; margin-left: 4px; }
  .timeline-item { padding-left: 18px; }
  .product-card img, .gallery-card img { height: 170px; }
  .footer-links li, .footer-links a { font-size: .95rem; }
}
