/*
Theme Name: Interior Designers Indore
Theme URI: https://interiordesignersindore.com/
Author: Amit Batham
Author URI: https://interiordesignersindore.com/
Description: Premium interior design theme for Interior Designers Indore studio. Luxury Indian aesthetic with Vastu integration, portfolio CPT, local SEO schema, and Settings API for easy content management. No ACF Pro required.
Version: 1.0.0
Requires at least: 6.0
Tested up to: 6.7
Requires PHP: 8.0
License: GPL v2 or later
License URI: https://www.gnu.org/licenses/gpl-2.0.html
Text Domain: idi
Tags: portfolio, business, custom-colors, custom-logo, full-width-template, block-editor-styles
*/

/* ============================================================
   DESIGN TOKENS
   ============================================================ */
:root {
  --idi-charcoal:    #1A1A2E;
  --idi-gold:        #C9A84C;
  --idi-gold-dark:   #A8872E;
  --idi-warm-white:  #FAF8F5;
  --idi-terracotta:  #C4714A;
  --idi-sage:        #7C9A7E;
  --idi-light-gray:  #F0ECEA;
  --idi-footer-bg:   #0f0f1f;
  --idi-font-display:'Cormorant Garamond', serif;
  --idi-font-body:   'DM Sans', sans-serif;
  --idi-font-accent: 'Jost', sans-serif;
}

/* ============================================================
   RESET & BASE
   ============================================================ */
*, *::before, *::after { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
  font-family: var(--idi-font-body);
  background: var(--idi-warm-white);
  color: var(--idi-charcoal);
  margin: 0;
  line-height: 1.65;
}
a { color: var(--idi-gold); text-decoration: none; }
a:hover { color: var(--idi-gold-dark); }
img { max-width: 100%; height: auto; display: block; }
h1,h2,h3,h4,h5,h6 {
  font-family: var(--idi-font-display);
  font-weight: 400;
  line-height: 1.15;
  color: var(--idi-charcoal);
  margin: 0 0 1rem;
}
p { margin: 0 0 1rem; }

/* ============================================================
   LAYOUT HELPERS
   ============================================================ */
.idi-container { max-width: 1280px; margin: 0 auto; padding: 0 24px; }
.idi-section { padding: 80px 24px; }
.idi-section--dark { background: var(--idi-charcoal); }
.idi-section--light-gray { background: var(--idi-light-gray); }

/* ============================================================
   TYPOGRAPHY UTILITIES
   ============================================================ */
.idi-display { font-family: var(--idi-font-display); }
.idi-accent  { font-family: var(--idi-font-accent); }
.idi-label {
  font-family: var(--idi-font-accent);
  font-size: 11px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--idi-gold);
  display: inline-flex;
  align-items: center;
  gap: 10px;
}
.idi-label::before {
  content: '';
  display: inline-block;
  width: 28px;
  height: 1px;
  background: var(--idi-gold);
}

/* ============================================================
   HEADER
   ============================================================ */
#idi-header {
  position: sticky;
  top: 0;
  z-index: 100;
  background: rgba(250,248,245,0.96);
  backdrop-filter: blur(12px);
  border-bottom: 1px solid rgba(201,168,76,0.15);
  transition: box-shadow 0.3s;
  height: 70px;
  display: flex;
  align-items: center;
}
#idi-header.scrolled { box-shadow: 0 2px 24px rgba(26,26,46,0.08); }
.idi-header-inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  width: 100%;
}
.idi-site-logo .logo-name {
  font-family: var(--idi-font-display);
  font-size: 22px;
  font-weight: 600;
  color: var(--idi-charcoal);
  line-height: 1.1;
  display: block;
}
.idi-site-logo .logo-tag {
  font-family: var(--idi-font-accent);
  font-size: 10px;
  letter-spacing: 0.2em;
  color: var(--idi-gold);
  text-transform: uppercase;
  display: block;
  margin-top: 1px;
}
.idi-nav { display: flex; gap: 32px; align-items: center; }
.idi-nav a {
  font-family: var(--idi-font-accent);
  font-size: 13px;
  letter-spacing: 0.06em;
  color: var(--idi-charcoal);
  text-decoration: none;
  text-transform: uppercase;
  transition: color 0.2s;
}
.idi-nav a:hover,
.idi-nav a.current-menu-item { color: var(--idi-gold); }
.idi-btn-primary {
  background: var(--idi-gold);
  color: var(--idi-charcoal) !important;
  font-family: var(--idi-font-accent);
  font-size: 13px;
  font-weight: 600;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  padding: 10px 22px;
  border-radius: 4px;
  text-decoration: none;
  display: inline-block;
  border: none;
  cursor: pointer;
  transition: background 0.2s;
}
.idi-btn-primary:hover { background: var(--idi-gold-dark); color: var(--idi-charcoal) !important; }
.idi-btn-outline {
  background: transparent;
  color: var(--idi-warm-white) !important;
  border: 1px solid rgba(250,248,245,0.3);
  font-family: var(--idi-font-accent);
  font-size: 13px;
  font-weight: 500;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  padding: 10px 22px;
  border-radius: 4px;
  text-decoration: none;
  display: inline-block;
  transition: border-color 0.2s,color 0.2s;
}
.idi-btn-outline:hover { border-color: var(--idi-gold); color: var(--idi-gold) !important; }

/* Mobile hamburger */
.idi-hamburger {
  display: none;
  background: none;
  border: none;
  cursor: pointer;
  padding: 8px;
  color: var(--idi-charcoal);
}

/* ============================================================
   MOBILE DRAWER
   ============================================================ */
#idi-drawer {
  position: fixed;
  top: 0; left: 0;
  height: 100vh;
  width: 80%;
  max-width: 320px;
  background: var(--idi-charcoal);
  z-index: 200;
  transform: translateX(-100%);
  transition: transform 0.35s cubic-bezier(0.4,0,0.2,1);
  padding: 24px;
  overflow-y: auto;
}
#idi-drawer-overlay {
  position: fixed;
  inset: 0;
  background: rgba(26,26,46,0.5);
  z-index: 199;
  display: none;
}
#idi-drawer.open { transform: translateX(0); }
#idi-drawer-overlay.open { display: block; }
.drawer-nav a {
  display: block;
  color: rgba(250,248,245,0.7);
  font-family: var(--idi-font-accent);
  font-size: 15px;
  padding: 12px 0;
  border-bottom: 1px solid rgba(255,255,255,0.08);
  text-decoration: none;
}
.drawer-nav a:hover,
.drawer-nav a.current-menu-item { color: var(--idi-gold); }

/* ============================================================
   WHATSAPP BUTTON
   ============================================================ */
#idi-whatsapp {
  position: fixed;
  bottom: 24px;
  right: 24px;
  z-index: 150;
  width: 58px;
  height: 58px;
  background: #25D366;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  box-shadow: 0 4px 20px rgba(37,211,102,0.4);
  transition: transform 0.2s, box-shadow 0.2s;
  text-decoration: none;
}
#idi-whatsapp:hover {
  transform: scale(1.08);
  box-shadow: 0 6px 28px rgba(37,211,102,0.5);
}

/* ============================================================
   HERO
   ============================================================ */
.idi-hero {
  background: var(--idi-charcoal) !important;
  min-height: calc(100vh - 70px);
  display: flex;
  align-items: center;
  position: relative;
  overflow: hidden;
}
.idi-hero-inner {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 60px;
  align-items: center;
  width: 100%;
}

/* ============================================================
   PROJECT CARDS
   ============================================================ */
.idi-project-card {
  border-radius: 14px;
  overflow: hidden;
  background: white;
  box-shadow: 0 2px 16px rgba(26,26,46,0.07);
  transition: transform 0.3s ease, box-shadow 0.3s ease;
  cursor: pointer;
}
.idi-project-card:hover {
  transform: translateY(-6px);
  box-shadow: 0 20px 60px rgba(26,26,46,0.14);
}
.idi-project-card__thumb { height: 240px; position: relative; overflow: hidden; }
.idi-project-card__overlay {
  position: absolute;
  inset: 0;
  background: rgba(26,26,46,0.72);
  display: flex;
  align-items: center;
  justify-content: center;
  opacity: 0;
  transition: opacity 0.3s;
}
.idi-project-card:hover .idi-project-card__overlay { opacity: 1; }
.idi-project-card__cat {
  position: absolute;
  top: 14px;
  left: 14px;
  background: var(--idi-gold);
  padding: 3px 12px;
  border-radius: 20px;
  font-family: var(--idi-font-accent);
  font-size: 10px;
  color: var(--idi-charcoal);
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.06em;
}
.idi-project-card__title {
  position: absolute;
  bottom: 14px;
  left: 14px;
  right: 14px;
  font-family: var(--idi-font-display);
  font-size: 20px;
  font-weight: 500;
  color: var(--idi-warm-white);
  line-height: 1.2;
}
.idi-project-card__body { padding: 18px 22px; }
.idi-project-card__meta {
  font-family: var(--idi-font-accent);
  font-size: 12px;
  color: #888;
  display: flex;
  align-items: center;
  gap: 5px;
}
.idi-project-card__price {
  font-family: var(--idi-font-accent);
  font-size: 12px;
  color: var(--idi-terracotta);
  font-weight: 600;
}

/* ============================================================
   TESTIMONIALS
   ============================================================ */
.idi-testimonial {
  background: white;
  border-radius: 12px;
  padding: 28px;
  border-top: 3px solid var(--idi-gold);
}
.idi-testimonial blockquote {
  font-family: var(--idi-font-display);
  font-size: 17px;
  font-style: italic;
  color: var(--idi-charcoal);
  line-height: 1.75;
  margin: 0 0 20px;
}

/* ============================================================
   BLOG CARDS
   ============================================================ */
.idi-blog-card {
  background: white;
  border-radius: 14px;
  overflow: hidden;
  box-shadow: 0 2px 16px rgba(26,26,46,0.06);
  transition: transform 0.3s, box-shadow 0.3s;
}
.idi-blog-card:hover {
  transform: translateY(-4px);
  box-shadow: 0 12px 40px rgba(26,26,46,0.12);
}
.idi-blog-card__thumb { height: 200px; overflow: hidden; }
.idi-blog-card__thumb img { width: 100%; height: 100%; object-fit: cover; }
.idi-blog-card__body { padding: 24px; }
.idi-blog-card__cat {
  font-family: var(--idi-font-accent);
  font-size: 10px;
  background: rgba(201,168,76,0.1);
  color: var(--idi-gold-dark);
  padding: 3px 10px;
  border-radius: 12px;
  font-weight: 600;
  display: inline-block;
  margin-bottom: 12px;
}
.idi-blog-card h3 {
  font-family: var(--idi-font-display);
  font-size: 20px;
  margin: 0 0 10px;
  line-height: 1.35;
}

/* ============================================================
   SERVICE SECTIONS
   ============================================================ */
.idi-service-block {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 72px;
  align-items: center;
}
.idi-service-block__image {
  border-radius: 14px;
  overflow: hidden;
  aspect-ratio: 4/3;
  background: var(--idi-charcoal);
}
.idi-service-block__image img { width: 100%; height: 100%; object-fit: cover; }
.idi-checklist { list-style: none; padding: 0; margin: 0 0 24px; }
.idi-checklist li {
  display: flex;
  gap: 10px;
  align-items: flex-start;
  margin-bottom: 12px;
  font-family: var(--idi-font-body);
  font-size: 14px;
  color: #444;
}
.idi-checklist li::before {
  content: '';
  width: 16px;
  height: 16px;
  border: 1.5px solid var(--idi-gold);
  border-radius: 50%;
  flex-shrink: 0;
  margin-top: 2px;
  background: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='8' viewBox='0 0 24 24' fill='none' stroke='%23C9A84C' stroke-width='3'%3E%3Cpolyline points='20 6 9 17 4 12'/%3E%3C/svg%3E") center/10px no-repeat;
}

/* ============================================================
   PRICING
   ============================================================ */
.idi-pricing-card {
  background: white;
  border-radius: 14px;
  padding: 36px 28px;
  border: 1px solid rgba(201,168,76,0.15);
}
.idi-pricing-card--popular {
  border: 2px solid var(--idi-gold);
  position: relative;
}
.idi-pricing-card--popular::before {
  content: 'Most Popular';
  position: absolute;
  top: -13px;
  left: 50%;
  transform: translateX(-50%);
  background: var(--idi-gold);
  color: var(--idi-charcoal);
  font-family: var(--idi-font-accent);
  font-size: 11px;
  font-weight: 600;
  letter-spacing: 0.08em;
  padding: 3px 16px;
  border-radius: 20px;
  white-space: nowrap;
}

/* ============================================================
   FOOTER
   ============================================================ */
#idi-footer {
  background: var(--idi-footer-bg);
  padding: 56px 24px 28px;
  color: rgba(250,248,245,0.4);
}
.idi-footer-grid {
  display: grid;
  grid-template-columns: 2fr 1fr 1fr 1fr;
  gap: 40px;
  margin-bottom: 48px;
}
.idi-footer-heading {
  font-family: var(--idi-font-accent);
  font-size: 11px;
  letter-spacing: 0.15em;
  text-transform: uppercase;
  color: var(--idi-gold);
  margin: 0 0 16px;
}
.idi-footer-link {
  font-family: var(--idi-font-body);
  font-size: 13px;
  color: rgba(250,248,245,0.45);
  text-decoration: none;
  display: block;
  margin-bottom: 9px;
  transition: color 0.2s;
}
.idi-footer-link:hover { color: var(--idi-gold); }
.idi-footer-bottom {
  border-top: 1px solid rgba(201,168,76,0.1);
  padding-top: 24px;
  display: flex;
  justify-content: space-between;
  align-items: center;
  flex-wrap: wrap;
  gap: 12px;
}
.idi-footer-copy { font-family: var(--idi-font-body); font-size: 12px; }

/* ============================================================
   FORMS
   ============================================================ */
.idi-form-group { margin-bottom: 20px; }
.idi-form-label {
  font-family: var(--idi-font-accent);
  font-size: 11px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: #888;
  display: block;
  margin-bottom: 6px;
}
.idi-form-input {
  width: 100%;
  padding: 12px 16px;
  border: 1px solid rgba(26,26,46,0.15);
  border-radius: 6px;
  font-family: var(--idi-font-body);
  font-size: 14px;
  color: var(--idi-charcoal);
  background: white;
  outline: none;
  transition: border-color 0.2s;
}
.idi-form-input:focus { border-color: var(--idi-gold); }

/* ============================================================
   FAQ
   ============================================================ */
.idi-faq-item { border-bottom: 1px solid rgba(26,26,46,0.08); }
.idi-faq-question {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 20px 0;
  cursor: pointer;
  font-family: var(--idi-font-body);
  font-size: 15px;
  color: var(--idi-charcoal);
  font-weight: 500;
  user-select: none;
}
.idi-faq-answer { max-height: 0; overflow: hidden; transition: max-height 0.35s ease, padding 0.2s; }
.idi-faq-item.open .idi-faq-answer { max-height: 200px; padding-bottom: 16px; }
.idi-faq-item.open .idi-faq-icon { transform: rotate(45deg); }
.idi-faq-icon { transition: transform 0.3s; color: var(--idi-gold); flex-shrink: 0; }
.idi-faq-answer p { font-family: var(--idi-font-body); font-size: 14px; color: #555; line-height: 1.75; margin: 0; }

/* ============================================================
   FILTER BUTTONS
   ============================================================ */
.idi-filter-bar { display: flex; gap: 10px; overflow-x: auto; scrollbar-width: none; }
.idi-filter-btn {
  font-family: var(--idi-font-accent);
  font-size: 12px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  padding: 9px 20px;
  border-radius: 24px;
  border: 1px solid rgba(201,168,76,0.3);
  background: transparent;
  color: var(--idi-charcoal);
  cursor: pointer;
  white-space: nowrap;
  transition: all 0.2s;
}
.idi-filter-btn.active,
.idi-filter-btn:hover {
  background: var(--idi-charcoal);
  color: var(--idi-gold);
  border-color: var(--idi-charcoal);
}

/* ============================================================
   ANIMATIONS
   ============================================================ */
@keyframes idi-fadeUp {
  from { opacity: 0; transform: translateY(24px); }
  to   { opacity: 1; transform: translateY(0); }
}
.idi-fade-up { animation: idi-fadeUp 0.6s ease forwards; }
.idi-delay-1 { animation-delay: 0.15s; opacity: 0; }
.idi-delay-2 { animation-delay: 0.3s;  opacity: 0; }
.idi-delay-3 { animation-delay: 0.45s; opacity: 0; }
.idi-delay-4 { animation-delay: 0.6s;  opacity: 0; }

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (max-width: 1024px) {
  .idi-footer-grid { grid-template-columns: 1fr 1fr; }
  .idi-service-block { grid-template-columns: 1fr; gap: 32px; }
  .idi-hero-inner { grid-template-columns: 1fr; }
}
@media (max-width: 768px) {
  .idi-nav { display: none; }
  .idi-hamburger { display: block; }
  .idi-footer-grid { grid-template-columns: 1fr; gap: 28px; }
  .idi-section { padding: 56px 16px; }
  .idi-hero { min-height: 85vh; }
}
@media (max-width: 480px) {
  .idi-footer-grid { grid-template-columns: 1fr; }
}

/* ============================================================
   WORDPRESS CORE COMPATIBILITY
   ============================================================ */
.wp-block-image img { border-radius: 8px; }
.wp-caption-text { font-family: var(--idi-font-body); font-size: 13px; color: #888; margin-top: 6px; }
.alignleft { float: left; margin: 0 24px 16px 0; }
.alignright { float: right; margin: 0 0 16px 24px; }
.aligncenter { display: block; margin: 0 auto 16px; }
.gallery { display: grid; grid-template-columns: repeat(3,1fr); gap: 12px; }
.gallery-item img { border-radius: 8px; }
.wp-block-separator { border: none; border-top: 1px solid rgba(201,168,76,0.2); margin: 40px 0; }

/* ============================================================
   SERVICE DETAIL PAGES
   ============================================================ */
.idi-service-hero { background: var(--idi-charcoal) !important; padding: 72px 24px 60px; position: relative; overflow: hidden; }
.idi-service-hero__glow { position:absolute;top:-80px;right:-80px;width:500px;height:500px;border-radius:50%;background:radial-gradient(circle,rgba(201,168,76,0.08) 0%,transparent 70%);pointer-events:none; }
.idi-service-hero__grid { max-width:1280px;margin:0 auto;display:grid;grid-template-columns:1fr auto;gap:40px;align-items:center;position:relative;z-index:2; }
.idi-service-stats-box { background:rgba(255,255,255,0.05);border:1px solid rgba(201,168,76,0.2);border-radius:16px;padding:32px 28px;min-width:200px;display:flex;flex-direction:column;gap:20px; }
.idi-service-stats-box__num { font-family:var(--idi-font-display);font-size:38px;font-weight:300;color:var(--idi-gold);line-height:1;text-align:center; }
.idi-service-stats-box__label { font-family:var(--idi-font-accent);font-size:10px;letter-spacing:0.12em;color:rgba(250,248,245,0.45);text-transform:uppercase;margin-top:4px;text-align:center; }
.idi-service-stats-box__divider { height:1px;background:rgba(201,168,76,0.15); }

/* Room / Feature tabs */
.idi-room-tabs { display:flex;gap:10px;overflow-x:auto;scrollbar-width:none;flex-wrap:wrap; }
.idi-room-tab { padding:10px 20px;border-radius:24px;border:1px solid rgba(201,168,76,0.25);background:transparent;font-family:var(--idi-font-accent);font-size:12px;letter-spacing:0.08em;text-transform:uppercase;color:var(--idi-charcoal);cursor:pointer;transition:all 0.2s;white-space:nowrap; }
.idi-room-tab:hover,.idi-room-tab.active { background:var(--idi-charcoal);color:var(--idi-gold);border-color:var(--idi-charcoal); }
.idi-room-panel { display:none;grid-template-columns:1fr 1fr;gap:48px;align-items:center; }
.idi-room-panel.active { display:grid; }
.idi-room-panel__thumb { border-radius:14px;overflow:hidden;aspect-ratio:4/3;background:var(--idi-charcoal); }
.idi-room-panel__thumb img { width:100%;height:100%;object-fit:cover; }

/* Spec cards */
.idi-spec-card { background:white;border-radius:12px;padding:24px;border:1px solid rgba(201,168,76,0.12);transition:border-color 0.2s; }
.idi-spec-card:hover { border-color:rgba(201,168,76,0.4); }
.idi-spec-card__icon { width:44px;height:44px;background:rgba(201,168,76,0.1);border-radius:10px;display:flex;align-items:center;justify-content:center;margin-bottom:14px; }

/* Kitchen layout cards */
.idi-layout-card { border-radius:12px;padding:24px;background:white;border:2px solid transparent;cursor:pointer;transition:all 0.2s; }
.idi-layout-card:hover,.idi-layout-card.active { border-color:var(--idi-gold);background:#fffdf8; }
.idi-layout-card__label { font-family:var(--idi-font-accent);font-size:11px;letter-spacing:0.1em;text-transform:uppercase;color:var(--idi-gold);margin-bottom:6px; }

/* Pricing cards (service pages) */
.idi-pkg { background:white;border-radius:14px;padding:32px 28px;border:1px solid rgba(201,168,76,0.15);position:relative; }
.idi-pkg--popular { border:2px solid var(--idi-gold); }
.idi-pkg--popular::before { content:'Most Popular';position:absolute;top:-13px;left:50%;transform:translateX(-50%);background:var(--idi-gold);color:var(--idi-charcoal);font-family:var(--idi-font-accent);font-size:11px;font-weight:700;letter-spacing:0.08em;padding:3px 16px;border-radius:20px;white-space:nowrap; }
.idi-pkg--dark { background:rgba(255,255,255,0.04);border-color:rgba(201,168,76,0.15); }
.idi-pkg__tier { font-family:var(--idi-font-accent);font-size:12px;letter-spacing:0.12em;text-transform:uppercase;color:var(--idi-gold);margin-bottom:12px; }
.idi-pkg__price { font-family:var(--idi-font-display);font-size:48px;font-weight:300;line-height:1;margin-bottom:4px; }
.idi-pkg__ideal { font-family:var(--idi-font-body);font-size:12px;margin-bottom:28px; }

/* Process timeline */
.idi-step { display:flex;gap:24px;position:relative; }
.idi-step:not(:last-child) { padding-bottom:36px; }
.idi-step:not(:last-child)::before { content:'';position:absolute;left:19px;top:44px;bottom:0;width:2px;background:linear-gradient(to bottom,var(--idi-gold),rgba(201,168,76,0.1)); }
.idi-step__num { width:40px;height:40px;border-radius:50%;background:var(--idi-gold);display:flex;align-items:center;justify-content:center;flex-shrink:0;font-family:var(--idi-font-accent);font-size:13px;font-weight:700;color:var(--idi-charcoal);z-index:1; }
.idi-step__title { font-family:var(--idi-font-accent);font-size:16px;font-weight:600;color:var(--idi-charcoal);margin:0 0 6px; }
.idi-step__text { font-family:var(--idi-font-body);font-size:14px;color:#666;line-height:1.75;margin:0; }

/* Vastu / spec grids */
.idi-vastu-grid { display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:20px; }

/* Responsive overrides */
@media (max-width:768px) {
  .idi-service-hero__grid { grid-template-columns:1fr; }
  .idi-service-stats-box { flex-direction:row;flex-wrap:wrap;justify-content:center;min-width:unset; }
  .idi-room-panel.active { grid-template-columns:1fr; }
}
