/* Dhanvastra shared storefront theme — extracted from landing inline styles */

    /* Dudeme Theme Colors & Variable Overrides */
    :root {
      --accent-red: #1c1b19;
      --accent-red-hover: #000000;
      --text-dark: #1c1b19;
      --bg-light: #faf6f0;
      --border-gray: rgba(28, 27, 25, 0.1);
      --font-body: 'Outfit', sans-serif;
      --font-logo: 'Cormorant Garamond', serif;
    }

    body {
      font-family: var(--font-body);
      color: var(--text-dark);
      background-color: #ffffff;
    }

    /* Announcement Bar */
    .promo-banner {
      background-color: var(--text-dark);
      color: #ffffff;
      font-size: 0.8rem;
      font-weight: 700;
      text-transform: uppercase;
      letter-spacing: 1.5px;
      padding: 10px 20px;
      text-align: center;
      position: relative;
      overflow: hidden;
    }
    .promo-ticker {
      display: inline-block;
      white-space: nowrap;
      animation: ticker-slide 20s linear infinite;
    }
    @keyframes ticker-slide {
      0% { transform: translateX(50%); }
      100% { transform: translateX(-50%); }
    }

    /* Header adjustments */
    .top-header {
      padding: 15px 40px;
      background: #ffffff;
      border-bottom: 1px solid var(--border-gray);
    }
    .brand-logo {
      font-family: var(--font-logo);
      font-size: 2.3rem;
      font-weight: 700;
      letter-spacing: -1px;
      color: var(--text-dark);
    }
    .brand-logo span {
      color: var(--accent-red);
    }

    .btn-shop-primary {
      background-color: var(--accent-red) !important;
      color: #ffffff !important;
      transition: background-color 0.2s;
    }
    .btn-shop-primary:hover {
      background-color: var(--accent-red-hover) !important;
    }

    /* Navigation Bar */
    .main-nav-bar {
      border-bottom: 1px solid var(--border-gray);
      background-color: #ffffff;
    }
    .nav-item-link {
      font-family: var(--font-body);
      font-weight: 700;
      color: var(--text-dark) !important;
      text-transform: uppercase;
      font-size: 0.85rem;
      letter-spacing: 0.5px;
    }
    .nav-item-link.active {
      color: var(--accent-red) !important;
    }

    /* Main Geek Hero Slider Layout */
    .hero-slider-section {
      display: grid;
      grid-template-columns: 1fr 1fr;
      background-color: var(--bg-light);
      align-items: center;
      min-height: 520px;
      padding: 40px 80px;
      gap: 40px;
      border-bottom: 1px solid var(--border-gray);
    }
    @media (max-width: 992px) {
      .hero-slider-section {
        grid-template-columns: 1fr;
        text-align: center;
        padding: 40px 20px;
      }
    }
    .hero-content {
      display: flex;
      flex-direction: column;
      gap: 20px;
    }
    .hero-title-badge {
      background-color: var(--text-dark);
      color: #ffffff;
      width: fit-content;
      padding: 6px 14px;
      font-size: 0.8rem;
      font-weight: 700;
      text-transform: uppercase;
      border-radius: 4px;
      letter-spacing: 1px;
    }
    @media (max-width: 992px) {
      .hero-title-badge { margin: 0 auto; }
    }
    .hero-main-title {
      font-family: var(--font-body);
      font-family: var(--font-logo);
      font-weight: 500;
      font-size: 3.8rem;
      text-transform: none;
      line-height: 1.05;
      text-transform: uppercase;
      color: var(--text-dark);
    }
    .hero-main-title span {
      color: var(--accent-red);
    }
    .hero-desc {
      font-size: 1.15rem;
      color: #555555;
      line-height: 1.6;
    }
    .hero-action-row {
      display: flex;
      gap: 15px;
      margin-top: 10px;
    }
    @media (max-width: 992px) {
      .hero-action-row { justify-content: center; }
    }
    .btn-hero-red {
      background: var(--accent-red);
      color: #ffffff;
      padding: 15px 35px;
      font-size: 1rem;
      font-weight: 700;
      border-radius: 30px;
      text-decoration: none;
      text-transform: uppercase;
      letter-spacing: 1px;
      transition: background-color 0.2s;
    }
    .btn-hero-red:hover {
      background: var(--accent-red-hover);
    }

    /* Geek graphic container */
    .hero-graphic-box {
      display: flex;
      justify-content: center;
      position: relative;
    }
    .hero-design-shirt-mockup {
      width: 80%;
      max-width: 420px;
      aspect-ratio: 1/1;
      background: #ffffff;
      border-radius: 50%;
      padding: 20px;
      box-shadow: 0 15px 40px rgba(0,0,0,0.06);
      border: 1px solid var(--border-gray);
      position: relative;
      overflow: hidden;
    }
    .hero-design-graphic-overlay {
      position: absolute;
      left: 28%;
      top: 22%;
      width: 44%;
      height: 52%;
      display: flex;
      align-items: center;
      justify-content: center;
    }
    .hero-design-graphic-overlay img {
      max-width: 90%;
      max-height: 90%;
      object-fit: contain;
    }

    /* Circular category bubbles */
    .category-bubbles-section {
      padding: 50px 0;
      border-bottom: 1px solid var(--border-gray);
    }
    .bubbles-container {
      display: flex;
      justify-content: center;
      gap: 40px;
      flex-wrap: wrap;
    }
    .bubble-card {
      display: flex;
      flex-direction: column;
      align-items: center;
      gap: 12px;
      text-decoration: none;
      transition: transform 0.2s;
    }
    .bubble-card:hover {
      transform: translateY(-6px);
    }
    .bubble-circle {
      width: 100px;
      height: 100px;
      border-radius: 50%;
      background-color: var(--bg-light);
      display: flex;
      align-items: center;
      justify-content: center;
      overflow: hidden;
      border: 1px solid var(--border-gray);
      box-shadow: 0 8px 16px rgba(0,0,0,0.05);
    }
    .bubble-circle svg {
      color: var(--text-dark);
      width: 40px;
      height: 40px;
    }
    .bubble-label {
      font-size: 0.9rem;
      font-weight: 700;
      color: var(--text-dark);
      text-transform: uppercase;
      letter-spacing: 0.5px;
    }

    /* Product cards adjustments */
    .favorite-product-card {
      border: 1px solid var(--border-gray);
      border-radius: 8px;
      overflow: hidden;
      background: #ffffff;
      transition: box-shadow 0.2s;
    }
    .favorite-product-card:hover {
      box-shadow: 0 10px 25px rgba(0,0,0,0.08);
    }

    .fav-brand {
      color: var(--accent-red);
      font-weight: 700;
      text-transform: uppercase;
      font-size: 0.75rem;
    }

    .fav-price-row {
      display: flex;
      align-items: center;
      gap: 10px;
    }
    .price-struck {
      text-decoration: line-through;
      color: var(--text-muted);
      font-size: 0.95rem;
    }

    /* Grid layout */
    .bestseller-title-section {
      text-align: center;
      padding: 60px 0 20px 0;
    }
    .bestseller-title-section h2 {
      font-family: var(--font-body);
      font-weight: 900;
      font-size: 2.5rem;
      text-transform: uppercase;
    }

    /* Reviews section */
    .reviews-badge-container {
      background-color: var(--bg-light);
      padding: 60px 0;
      border-top: 1px solid var(--border-gray);
      border-bottom: 1px solid var(--border-gray);
      text-align: center;
    }
    .reviews-stars {
      display: flex;
      justify-content: center;
      gap: 6px;
      color: #ffb700;
      font-size: 1.5rem;
      margin-bottom: 8px;
    }
    .reviews-badge-title {
      font-size: 1.8rem;
      font-weight: 900;
      text-transform: uppercase;
      margin-bottom: 8px;
    }

    .reviews-grid-row {
      display: grid;
      grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
      gap: 30px;
      margin-top: 40px;
      padding: 0 40px;
    }
    .review-bubble-card {
      background: #ffffff;
      padding: 24px;
      border-radius: 8px;
      border: 1px solid var(--border-gray);
      text-align: left;
      display: flex;
      flex-direction: column;
      gap: 12px;
    }
    .review-user-row {
      display: flex;
      align-items: center;
      gap: 8px;
    }
    .review-user-name {
      font-weight: 700;
      font-size: 0.95rem;
    }
    .review-badge-verified {
      background: #109533;
      color: #ffffff;
      font-size: 0.65rem;
      font-weight: 700;
      padding: 2px 6px;
      border-radius: 30px;
      text-transform: uppercase;
    }

    /* Footer layout */
    footer.app-footer {
      background-color: var(--text-dark);
      color: #878787;
      padding: 60px 40px 30px 40px;
    }
    .footer-layout-row {
      display: grid;
      grid-template-columns: 2fr 1fr 1fr 2fr;
      gap: 40px;
      margin-bottom: 40px;
    }
    @media (max-width: 768px) {
      .footer-layout-row {
        grid-template-columns: 1fr;
      }
    }
    .footer-col {
      display: flex;
      flex-direction: column;
      gap: 16px;
    }
    .footer-col h4 {
      color: #ffffff;
      font-weight: 700;
      text-transform: uppercase;
      font-size: 0.95rem;
      letter-spacing: 0.5px;
    }
    .footer-links-list {
      display: flex;
      flex-direction: column;
      gap: 10px;
      list-style: none;
    }
    .footer-links-list a {
      color: #878787;
      text-decoration: none;
      font-size: 0.9rem;
      transition: color 0.2s;
    }
    .footer-links-list a:hover {
      color: #ffffff;
    }
    .footer-brand-title {
      font-family: var(--font-logo);
      font-size: 2.1rem;
      font-weight: 700;
      color: #ffffff;
      margin: 0;
    }
    .footer-brand-title span {
      color: var(--accent-red);
    }
    .footer-guarantees-row {
      display: grid;
      grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
      gap: 20px;
      border-bottom: 1px solid rgba(255,255,255,0.08);
      padding-bottom: 30px;
      margin-bottom: 30px;
    }
    .guarantee-card {
      display: flex;
      align-items: center;
      gap: 12px;
      color: #ffffff;
    }
    .guarantee-card svg {
      color: var(--accent-red);
      width: 28px;
      height: 28px;
    }
    .guarantee-text h5 {
      color: #ffffff;
      font-size: 0.9rem;
      margin-bottom: 2px;
    }
    .guarantee-text p {
      font-size: 0.8rem;
      color: #878787;
    }
  