/*
Theme Name: CHOGM Road
Theme URI: https://chogmroad.com
Author: CHOGM Road Team
Author URI: https://chogmroad.com
Description: A premium dark-themed WordPress theme for CHOGM Road, Porvorim, Goa. Designed for restaurants, nightlife, events, shopping and business discovery. Elementor compatible.
Version: 1.0.0
Requires at least: 6.0
Tested up to: 6.5
Requires PHP: 8.0
License: GNU General Public License v2 or later
License URI: https://www.gnu.org/licenses/gpl-2.0.html
Text Domain: chogmroad
Tags: dark, custom-menu, featured-images, threaded-comments, translation-ready, elementor

*/

/* ============================================================
   CHOGM ROAD – Base Styles (Elementor overrides in elementor-custom.css)
   ============================================================ */

:root {
    --cr-black:       #0a0a0f;
    --cr-deep:        #0d0d1a;
    --cr-card:        #111120;
    --cr-border:      #1e1e35;
    --cr-purple:      #a855f7;
    --cr-purple-dark: #7c3aed;
    --cr-pink:        #ec4899;
    --cr-blue:        #38bdf8;
    --cr-gold:        #f59e0b;
    --cr-teal:        #2dd4bf;
    --cr-text:        #e2e8f0;
    --cr-muted:       #64748b;
    --cr-dim:         #94a3b8;
    --cr-font-display: 'Bebas Neue', cursive;
    --cr-font-heading: 'Barlow Condensed', sans-serif;
    --cr-font-body:    'Barlow', sans-serif;
    --cr-radius:       8px;
    --cr-radius-lg:    12px;
    --cr-transition:   all .2s ease;
}

*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

html { scroll-behavior: smooth; }

body {
    background-color: var(--cr-black);
    color: var(--cr-text);
    font-family: var(--cr-font-body);
    font-size: 16px;
    font-weight: 400;
    line-height: 1.65;
    -webkit-font-smoothing: antialiased;
}

/* ── Typography ── */
h1, h2, h3, h4, h5, h6 {
    font-family: var(--cr-font-heading);
    font-weight: 700;
    letter-spacing: .04em;
    text-transform: uppercase;
    line-height: 1.1;
    color: #fff;
}

h1 { font-family: var(--cr-font-display); font-size: clamp(48px, 8vw, 100px); letter-spacing: .05em; }
h2 { font-size: clamp(32px, 5vw, 56px); }
h3 { font-size: clamp(22px, 3vw, 32px); }
h4 { font-size: 20px; }
h5 { font-size: 16px; }
h6 { font-size: 14px; }

p { margin-bottom: 1.25rem; color: var(--cr-dim); }
p:last-child { margin-bottom: 0; }

a { color: var(--cr-purple); text-decoration: none; transition: var(--cr-transition); }
a:hover { color: var(--cr-pink); }

img { max-width: 100%; height: auto; display: block; }

ul, ol { padding-left: 1.5rem; color: var(--cr-dim); }
li { margin-bottom: .4rem; }

blockquote {
    border-left: 3px solid var(--cr-purple);
    padding: 1rem 1.5rem;
    font-size: 1.2rem;
    font-style: italic;
    color: var(--cr-dim);
    margin: 2rem 0;
    background: rgba(168,85,247,0.05);
    border-radius: 0 var(--cr-radius) var(--cr-radius) 0;
}

hr {
    border: none;
    border-top: 1px solid var(--cr-border);
    margin: 3rem 0;
}

/* ── Layout ── */
.container {
    max-width: 1200px;
    margin: 0 auto;
    padding: 0 1.5rem;
}

.container--wide { max-width: 1440px; }
.container--narrow { max-width: 860px; }

.section {
    padding: 5rem 0;
}

.section--dark { background: var(--cr-deep); }
.section--darker { background: var(--cr-black); }

/* ── Buttons ── */
.btn {
    display: inline-flex;
    align-items: center;
    gap: .5rem;
    font-family: var(--cr-font-heading);
    font-size: 14px;
    font-weight: 700;
    letter-spacing: .12em;
    text-transform: uppercase;
    padding: .75rem 2rem;
    border-radius: var(--cr-radius);
    border: none;
    cursor: pointer;
    transition: var(--cr-transition);
    text-decoration: none;
}

.btn--primary {
    background: linear-gradient(135deg, var(--cr-purple), var(--cr-pink));
    color: #fff;
}
.btn--primary:hover { opacity: .85; transform: translateY(-2px); color: #fff; }

.btn--outline {
    background: transparent;
    border: 1px solid rgba(168,85,247,.5);
    color: var(--cr-purple);
}
.btn--outline:hover { background: rgba(168,85,247,.12); color: #fff; border-color: var(--cr-purple); }

.btn--ghost {
    background: transparent;
    color: var(--cr-dim);
    border: 1px solid var(--cr-border);
}
.btn--ghost:hover { color: #fff; border-color: var(--cr-dim); }

.btn--sm { padding: .5rem 1.25rem; font-size: 12px; }
.btn--lg { padding: 1rem 2.5rem; font-size: 16px; }

/* ── Cards ── */
.cr-card {
    background: var(--cr-card);
    border: 1px solid var(--cr-border);
    border-radius: var(--cr-radius-lg);
    overflow: hidden;
    transition: var(--cr-transition);
}
.cr-card:hover {
    border-color: rgba(168,85,247,.4);
    transform: translateY(-4px);
    box-shadow: 0 20px 60px rgba(0,0,0,.4);
}

.cr-card__thumb {
    position: relative;
    overflow: hidden;
    aspect-ratio: 16/10;
    background: var(--cr-deep);
}
.cr-card__thumb img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: transform .4s ease;
}
.cr-card:hover .cr-card__thumb img { transform: scale(1.05); }

.cr-card__body { padding: 1.5rem; }

.cr-card__cat {
    font-family: var(--cr-font-heading);
    font-size: 11px;
    font-weight: 700;
    letter-spacing: .15em;
    text-transform: uppercase;
    color: var(--cr-purple);
    margin-bottom: .4rem;
    display: block;
}

.cr-card__title {
    font-family: var(--cr-font-heading);
    font-size: 20px;
    font-weight: 700;
    color: #fff;
    margin-bottom: .5rem;
    text-transform: uppercase;
    letter-spacing: .04em;
    line-height: 1.2;
}

.cr-card__desc {
    font-size: 14px;
    color: var(--cr-muted);
    line-height: 1.6;
    margin-bottom: 1rem;
}

.cr-card__meta {
    display: flex;
    align-items: center;
    gap: .75rem;
    flex-wrap: wrap;
}

/* ── Badges ── */
.badge {
    display: inline-flex;
    align-items: center;
    font-family: var(--cr-font-heading);
    font-size: 11px;
    font-weight: 700;
    letter-spacing: .1em;
    text-transform: uppercase;
    padding: 3px 10px;
    border-radius: 4px;
}
.badge--purple { background: rgba(168,85,247,.15); color: var(--cr-purple); }
.badge--pink   { background: rgba(236,72,153,.15);  color: var(--cr-pink); }
.badge--blue   { background: rgba(56,189,248,.15);  color: var(--cr-blue); }
.badge--gold   { background: rgba(245,158,11,.15);  color: var(--cr-gold); }
.badge--teal   { background: rgba(45,212,191,.15);  color: var(--cr-teal); }
.badge--green  { background: rgba(34,197,94,.15);   color: #22c55e; }

/* ── Section Labels ── */
.section-label {
    display: block;
    font-family: var(--cr-font-heading);
    font-size: 12px;
    font-weight: 700;
    letter-spacing: .2em;
    text-transform: uppercase;
    color: var(--cr-purple);
    margin-bottom: .75rem;
}

.section-title {
    font-family: var(--cr-font-display);
    font-size: clamp(36px, 5vw, 64px);
    letter-spacing: .04em;
    color: #fff;
    margin-bottom: .75rem;
    line-height: 1;
}

.section-desc {
    font-size: 17px;
    font-weight: 300;
    color: var(--cr-dim);
    max-width: 580px;
    line-height: 1.7;
}

/* ── Grid helpers ── */
.cr-grid { display: grid; gap: 1.5rem; }
.cr-grid--2 { grid-template-columns: repeat(2, 1fr); }
.cr-grid--3 { grid-template-columns: repeat(3, 1fr); }
.cr-grid--4 { grid-template-columns: repeat(4, 1fr); }
.cr-grid--auto { grid-template-columns: repeat(auto-fill, minmax(280px, 1fr)); }

/* ── Star Rating ── */
.cr-rating { display: flex; align-items: center; gap: .3rem; }
.cr-rating__stars { color: var(--cr-gold); font-size: 14px; }
.cr-rating__count { font-size: 13px; color: var(--cr-muted); }

/* ── Neon Divider ── */
.neon-divider {
    height: 1px;
    background: linear-gradient(90deg, transparent, var(--cr-purple), var(--cr-pink), transparent);
    border: none;
    margin: 0;
}

/* ── Gradient Text ── */
.gradient-text {
    background: linear-gradient(135deg, #fff 20%, var(--cr-purple) 60%, var(--cr-pink) 100%);
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    background-clip: text;
}

.gradient-text--blue {
    background: linear-gradient(135deg, var(--cr-blue), var(--cr-purple));
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    background-clip: text;
}

/* ── Utility ── */
.text-center { text-align: center; }
.text-muted   { color: var(--cr-muted); }
.text-purple  { color: var(--cr-purple); }
.text-pink    { color: var(--cr-pink); }
.text-gold    { color: var(--cr-gold); }
.mt-1 { margin-top: .5rem; }
.mt-2 { margin-top: 1rem; }
.mt-3 { margin-top: 1.5rem; }
.mt-4 { margin-top: 2rem; }
.mb-1 { margin-bottom: .5rem; }
.mb-2 { margin-bottom: 1rem; }
.mb-3 { margin-bottom: 1.5rem; }
.mb-4 { margin-bottom: 2rem; }
.flex  { display: flex; }
.flex-center { display: flex; align-items: center; justify-content: center; }
.gap-1 { gap: .5rem; }
.gap-2 { gap: 1rem; }
.gap-3 { gap: 1.5rem; }

/* ── Responsive ── */
@media (max-width: 1024px) {
    .cr-grid--4 { grid-template-columns: repeat(2, 1fr); }
    .cr-grid--3 { grid-template-columns: repeat(2, 1fr); }
}

@media (max-width: 768px) {
    .section { padding: 3.5rem 0; }
    .cr-grid--4,
    .cr-grid--3,
    .cr-grid--2 { grid-template-columns: 1fr; }
    h1 { font-size: clamp(40px, 10vw, 72px); }
}

@media (max-width: 480px) {
    .container { padding: 0 1rem; }
}
