/* ════════════════════════════════════════════════════════
   MR. GENTLEMAN — MASTER STYLESHEET
   File location: css/style.css
   All sizes, colours, spacing — edit the ← comments to adjust
════════════════════════════════════════════════════════ */

/* ── RESET ── */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; } /* ← overflow-x fixes horizontal scroll on all pages */
body {
    background: #1A202C;                    /* ← PAGE BACKGROUND */
    color: #f0ede8;
    font-family: 'Cormorant Garamond', serif; /* ← GLOBAL FONT */
    font-weight: 300;
    font-size: 1rem;
    line-height: 1.8;                       /* ← GLOBAL LINE HEIGHT */
    overflow-x: hidden;
}

/* ════════════════════════════════════════════════════════
   VARIABLES — edit here to change colours globally
════════════════════════════════════════════════════════ */
:root {
    --bg:          #1A202C;                 /* ← page background */
    --bg2:         #202834;                 /* ← card/button background */
    --bg3:         #252f3e;                 /* ← hover background */
    --gold:        #c9a84c;                 /* ← primary gold */
    --gold-light:  #e4c97b;                 /* ← bright gold — titles, active borders */
    --gold-dim:    #8a6d2f;                 /* ← dim gold — eyebrows, subtitles */
    --gold-pale:   rgba(201,168,76,0.12);
    --blue:        #4A9EE0;                 /* ← accent blue — links, button glow */
    --border:      rgba(201,168,76,0.18);
    --border-soft: rgba(255,255,255,0.06);
    --text:        #f0ede8;                 /* ← primary text */
    --text-muted:  #8a8880;                 /* ← body/secondary text */
    --text-faint:  #4a4845;                 /* ← very faint labels */
    --transition:  0.3s cubic-bezier(0.25, 0.46, 0.45, 0.94);
}

/* ════════════════════════════════════════════════════════
   TYPOGRAPHY
════════════════════════════════════════════════════════ */
h1 {
    font-family: 'Pinyon Script', cursive;  /* ← H1 FONT */
    font-size: clamp(3rem, 6vw, 5.2rem);   /* ← H1 SIZE: min/fluid/max */
    font-weight: 400;
    color: var(--gold-light);
    line-height: 1.15;                     /* ← H1 LINE HEIGHT */
    letter-spacing: 0.02em;
    margin-bottom: 1.6rem;                 /* ← H1 BOTTOM MARGIN */
    text-shadow:
        0 0 2px rgba(0,0,0,0.95), 0 0 8px rgba(0,0,0,0.85),
        1px 1px 0 rgba(0,0,0,0.8), -1px -1px 0 rgba(0,0,0,0.8),
        1px -1px 0 rgba(0,0,0,0.8), -1px 1px 0 rgba(0,0,0,0.8),
        0 4px 18px rgba(0,0,0,0.5);
}

h2.section-title {
    font-family: 'Pinyon Script', cursive;  /* ← H2 FONT */
    font-size: clamp(2.4rem, 4vw, 3.6rem); /* ← H2 SIZE */
    font-weight: 400;
    line-height: 1.15;                     /* ← H2 LINE HEIGHT */
    letter-spacing: 0.02em;
    margin-bottom: 1.4rem;                 /* ← H2 BOTTOM MARGIN */
    padding-bottom: 0.15em;
    background: linear-gradient(110deg, #ffffff 0%, #c8d8f0 40%, var(--blue) 100%);
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    background-clip: text;
    display: inline-block;
}

h2.gold-title {
    font-family: 'Cormorant Garamond', serif; /* ← CARD TITLE FONT */
    font-style: italic; font-weight: 400;
    font-size: 1.65rem;                    /* ← CARD TITLE SIZE */
    line-height: 1.2; margin-bottom: 0.75rem;
    color: var(--gold-light); -webkit-text-fill-color: var(--gold-light); background: none;
}

h3 {
    font-family: 'Cormorant Garamond', serif; /* ← H3 FONT */
    font-style: italic; font-weight: 400;
    font-size: 1.4rem;                     /* ← H3 SIZE */
    color: var(--gold-light); margin-bottom: 0.75rem; line-height: 1.25;
}

h4 {
    font-family: 'Cormorant Garamond', serif;
    font-style: italic; font-size: 1.1rem; /* ← H4 SIZE */
    color: var(--text); margin-bottom: 1.3rem; letter-spacing: 0.03em;
}

/* Lead paragraph — first/highlighted paragraph in each section */
.lead {
    font-family: 'Cormorant Garamond', serif; /* ← LEAD FONT */
    font-size: 1.18rem;                    /* ← LEAD SIZE */
    font-weight: 400;
    color: var(--text-muted);              /* ← LEAD COLOUR (same as body outside hero) */
    line-height: 1.85; margin-bottom: 1.4rem;
}

/* Body paragraphs */
p {
    font-family: 'Cormorant Garamond', serif; /* ← BODY FONT */
    font-size: 1.08rem;                    /* ← BODY SIZE */
    color: var(--text-muted);              /* ← BODY COLOUR */
    margin-bottom: 1.2rem;                 /* ← BODY BOTTOM MARGIN */
    font-weight: 300;
    line-height: 1.85;                     /* ← BODY LINE HEIGHT */
    letter-spacing: 0.01em;
}
p:last-child { margin-bottom: 0; }

/* Hero — ALL text bright white */
.hero p, .hero .lead { color: rgba(255,255,255,0.92) !important; }

blockquote {
    border-left: 2px solid var(--gold-dim);
    padding: 1rem 1.5rem; margin: 1.5rem 0;
    font-style: italic; color: var(--text-muted); font-size: 1.1rem;
}

ul.styled-list, ol.styled-list {
    padding-left: 1.4rem; color: var(--text-muted); font-size: 1.05rem; line-height: 2;
}
ul.styled-list li::marker { color: var(--gold-dim); }

/* ════════════════════════════════════════════════════════
   LINKS
════════════════════════════════════════════════════════ */
a { color: var(--blue); text-decoration: none; transition: color var(--transition); }
a:hover { color: var(--gold-light); }

.text-link {
    font-family: 'Pinyon Script', cursive; /* ← TEXT LINK FONT — matches H1 */
    font-size: 1.3em;                      /* ← TEXT LINK SIZE relative to parent */
    color: var(--gold-light);
    border-bottom: 1px solid rgba(228,201,123,0.35);
    padding-bottom: 1px; font-weight: 400;
    line-height: 1; vertical-align: baseline;
    transition: border-color var(--transition), color var(--transition);
}
.text-link:hover { color: var(--gold); border-bottom-color: var(--gold); }

/* ════════════════════════════════════════════════════════
   EYEBROW LABELS + FADING GOLD LINES
════════════════════════════════════════════════════════ */
.eyebrow-wrap { display:flex; align-items:center; gap:10px; margin-bottom:1rem; overflow:hidden; }
.eyebrow-wrap.centered { justify-content:center; }
.eyebrow {
    font-family: 'Cormorant Garamond', serif;
    font-size: 0.72rem;                    /* ← EYEBROW SIZE */
    letter-spacing: 0.38em; text-transform: uppercase;
    color: var(--gold-dim); font-weight: 400; white-space: nowrap; flex-shrink: 0;
}
.eyebrow-line       { flex:1; height:1px; max-width:200px; background:linear-gradient(to right, rgba(201,168,76,0.55), rgba(201,168,76,0.2) 60%, transparent); }
.eyebrow-line-left  { flex:1; height:1px; max-width:120px; background:linear-gradient(to left,  rgba(201,168,76,0.55), rgba(201,168,76,0.15) 70%, transparent); }
.eyebrow-line-right { flex:1; height:1px; max-width:120px; background:linear-gradient(to right, rgba(201,168,76,0.55), rgba(201,168,76,0.15) 70%, transparent); }

/* ════════════════════════════════════════════════════════
   BUTTONS
   — dark-blue bg + bright gold border (same as chat popup)
   — permanent gold glow + blue glow on hover
════════════════════════════════════════════════════════ */
.btn {
    display: inline-flex; flex-direction: column; align-items: center; justify-content: center;
    text-align: center;
    background: rgba(20,26,38,0.97);       /* ← BUTTON BG */
    border: 1px solid rgba(201,168,76,0.55); /* ← BUTTON BORDER — bright gold */
    padding: 13px 28px;                    /* ← BUTTON PADDING */
    border-radius: 2px; cursor: pointer;
    position: relative; overflow: hidden; user-select: none;
    transition: border-color var(--transition), background var(--transition), box-shadow var(--transition);
    margin-top: 1.6rem; text-decoration: none;
    min-width: 160px;                      /* ← BUTTON MIN WIDTH */
}
.btn::after  { content:''; position:absolute; inset:0; background:radial-gradient(ellipse at 50% 0%, rgba(201,168,76,0.1), transparent 68%); opacity:1; pointer-events:none; z-index:0; }
.btn::before { content:''; position:absolute; inset:0; background:radial-gradient(ellipse at 50% 0%, rgba(74,158,224,0.2), transparent 72%); opacity:0; pointer-events:none; transition:opacity var(--transition); z-index:1; }
.btn:hover { border-color:var(--gold-light); background:rgba(30,38,54,0.98); box-shadow:0 0 16px rgba(201,168,76,0.28), 0 0 6px rgba(74,158,224,0.15), inset 0 1px 0 rgba(201,168,76,0.12); }
.btn:hover::before { opacity:1; }

.btn-label {
    display: block;
    font-family: 'Cormorant Garamond', serif; /* ← BUTTON LABEL FONT */
    font-size: 1.15rem;                    /* ← BUTTON LABEL SIZE */
    font-weight: 400; color: var(--text);  /* ← BUTTON LABEL COLOUR */
    letter-spacing: 0.03em;
    transition: color var(--transition); position: relative; z-index: 2;
}
.btn:hover .btn-label { color: var(--gold-light); }

.btn-sub {
    display: block;
    font-family: 'Jost', sans-serif;
    font-size: 0.65rem;                    /* ← BUTTON SUBTITLE SIZE */
    font-weight: 300; letter-spacing: 0.22em; text-transform: uppercase;
    color: var(--gold-dim);                /* ← BUTTON SUBTITLE COLOUR */
    margin-top: 3px; transition: color var(--transition); position: relative; z-index: 2;
}
.btn:hover .btn-sub { color: var(--gold); }

.btn--full { width:100%; margin-top:1rem; }

.btn--leave { border-color:rgba(255,255,255,0.15) !important; }
.btn--leave .btn-label { color:var(--text-muted) !important; }
.btn--leave .btn-sub   { color:var(--text-faint) !important; }
.btn--leave:hover { border-color:rgba(255,255,255,0.3) !important; box-shadow:none !important; }
.btn--leave:hover .btn-label { color:var(--text) !important; }

/* ════════════════════════════════════════════════════════
   LAYOUT
════════════════════════════════════════════════════════ */
.container     { width:90%; max-width:1500px; margin:0 auto; }  /* ← WIDE CONTAINER */
.container--narrow { width:90%; max-width:1200px; margin:0 auto; } /* ← CARD SECTIONS */
.container--hf { width:90%; max-width:1100px;  margin:0 auto; } /* ← HEADER & FOOTER */
section { position:relative; }

.split { display:grid; grid-template-columns:1fr 1fr; gap:5rem; align-items:center; } /* ← SPLIT GAP */

/* ════════════════════════════════════════════════════════
   HEADER
════════════════════════════════════════════════════════ */
header {
    position: absolute; top:0; left:50%; transform:translateX(-50%);
    width: 90%; max-width: 1100px;         /* ← HEADER WIDTH — matches footer */
    z-index: 100;
    padding: 2.2rem 0 1.4rem;             /* ← HEADER PADDING top/bottom */
    display: flex; justify-content: space-between; align-items: center;
}
header::after { /* divider line */
    content:''; position:absolute; bottom:0; left:0; right:0; height:1px;
    background:linear-gradient(to right, transparent 0%, rgba(201,168,76,0.2) 10%, rgba(201,168,76,0.55) 50%, rgba(201,168,76,0.2) 90%, transparent 100%);
}

.brand { display:flex; align-items:center; gap:10px; text-decoration:none; }
.brand-logo-img { width:36px; height:36px; object-fit:contain; display:block; } /* ← LOGO SIZE */
.brand-icon-fallback { width:24px; height:24px; fill:none; stroke:var(--gold-light); stroke-width:1.2; display:none; }
.brand-name {
    font-family: 'Pinyon Script', cursive; /* ← BRAND FONT */
    font-size: 2.4rem;                     /* ← BRAND SIZE */
    font-weight: 400; color: var(--gold-light);
    text-shadow: 0 1px 8px rgba(201,168,76,0.3), 0 0 24px rgba(201,168,76,0.1);
    line-height:1; letter-spacing:0.03em;
}

nav ul { display:flex; list-style:none; gap:1.6rem; align-items:center; } /* ← NAV GAP */
nav a {
    font-family: 'Cormorant Garamond', serif; /* ← NAV FONT */
    font-size: 1.05rem;                    /* ← NAV SIZE */
    font-style:italic; letter-spacing:0.06em;
    color: rgba(240,237,232,0.75);         /* ← NAV COLOUR */
    transition: color var(--transition); font-weight:300;
}
nav a:hover, nav a.active { color:var(--gold-light); }

/* Contact nav button — permanently in active/hover state */
.nav-cta {
    font-family: 'Cormorant Garamond', serif !important;
    font-size: 1.05rem !important; font-style:normal !important; letter-spacing:0.05em !important;
    background: rgba(30,38,54,0.98) !important; /* ← NAV CTA BG — always active */
    border: 1px solid var(--gold-light) !important; /* ← NAV CTA BORDER — bright gold, always */
    padding: 8px 18px !important;          /* ← NAV CTA PADDING */
    border-radius: 2px !important;
    color: var(--gold-light) !important;   /* ← NAV CTA TEXT — always gold */
    position:relative !important; overflow:hidden !important;
    box-shadow: 0 0 12px rgba(201,168,76,0.18) !important; /* ← NAV CTA GLOW — always on */
    transition: box-shadow var(--transition), border-color var(--transition) !important;
}
.nav-cta::after { content:''; position:absolute; inset:0; background:radial-gradient(ellipse at 50% 0%, rgba(201,168,76,0.1), transparent 68%); pointer-events:none; }
.nav-cta:hover { box-shadow:0 0 22px rgba(201,168,76,0.38), 0 0 8px rgba(228,201,123,0.2) !important; } /* ← NAV CTA HOVER — stronger glow */

.menu-icon { display:none; }
#menu-toggle { display:none; }

/* ════════════════════════════════════════════════════════
   HERO
════════════════════════════════════════════════════════ */
.hero {
    padding-top: 220px;                    /* ← HERO TOP PADDING */
    padding-bottom: 220px;                 /* ← HERO BOTTOM PADDING */
    background:
        linear-gradient(to bottom, rgba(26,32,44,0.45) 0%, rgba(26,32,44,0.72) 45%, rgba(26,32,44,0.97) 100%),
        url('/images/hero-santorini.jpg') no-repeat center center / cover; /* ← HERO BG IMAGE PATH */
    min-height: 100vh;
}

/* Inner page hero (smaller) */
.page-hero {
    padding-top: 200px;                    /* ← INNER HERO TOP */
    padding-bottom: 6rem;                  /* ← INNER HERO BOTTOM */
    background:
        linear-gradient(to bottom, rgba(26,32,44,0.5) 0%, rgba(26,32,44,0.85) 60%, rgba(26,32,44,0.98) 100%),
        url('/images/hero-santorini.jpg') no-repeat center center / cover;
    text-align: center;
}
.page-hero h1 { font-size:clamp(2.6rem, 5vw, 4.4rem); margin-bottom:1rem; }
.page-hero .lead { max-width:640px; margin:0 auto; color:rgba(255,255,255,0.85) !important; }

/* ════════════════════════════════════════════════════════
   GOLD DIVIDER LINE
════════════════════════════════════════════════════════ */
.divider { height:1px; border:none; margin:0; background:linear-gradient(to right, rgba(201,168,76,0) 0%, rgba(201,168,76,0.06) 8%, rgba(228,201,123,0.82) 50%, rgba(201,168,76,0.06) 92%, rgba(201,168,76,0) 100%); box-shadow:0 0 8px rgba(201,168,76,0.18); }
.divider-glow { width:100%; height:20px; background:linear-gradient(to bottom, rgba(201,168,76,0.04), transparent); }

/* ════════════════════════════════════════════════════════
   SECTION SPACING
════════════════════════════════════════════════════════ */
.section-pad    { padding: 9rem 0; }       /* ← SECTION PADDING */
.section-pad--sm { padding: 6rem 0; }      /* ← SMALL SECTION PADDING */
.section-tinted { background:linear-gradient(180deg, var(--bg) 0%, rgba(32,40,52,0.55) 50%, var(--bg) 100%); }
.section-fade-top::before   { content:''; position:absolute; top:0;    left:0; right:0; height:100px; background:linear-gradient(to bottom, var(--bg), transparent); pointer-events:none; }
.section-fade-bottom::after { content:''; position:absolute; bottom:0; left:0; right:0; height:100px; background:linear-gradient(to top,   var(--bg), transparent); pointer-events:none; }

/* ════════════════════════════════════════════════════════
   IMAGE FRAMES — inner thin frame + outer thicker frame + corner accents
════════════════════════════════════════════════════════ */
.img-frame { position:relative; width:100%; max-width:520px; justify-self:center; } /* ← MAX WIDTH */
.img-frame img { width:100%; height:100%; display:block; object-fit:cover; filter:grayscale(15%) brightness(85%) contrast(1.05); position:relative; z-index:1; }
.img-frame::before { content:''; position:absolute; inset:-6px;  border:1px solid rgba(201,168,76,0.45); z-index:2; pointer-events:none; } /* ← INNER FRAME */
.img-frame::after  { content:''; position:absolute; inset:-14px; border:2px solid rgba(201,168,76,0.2);  z-index:2; pointer-events:none; } /* ← OUTER FRAME */
.img-frame .corner { position:absolute; width:16px; height:16px; border-color:var(--gold-light); border-style:solid; z-index:4; }
.img-frame .corner-tl { top:-7px;    left:-7px;  border-width:1.5px 0 0 1.5px; }
.img-frame .corner-tr { top:-7px;    right:-7px; border-width:1.5px 1.5px 0 0; }
.img-frame .corner-bl { bottom:-7px; left:-7px;  border-width:0 0 1.5px 1.5px; }
.img-frame .corner-br { bottom:-7px; right:-7px; border-width:0 1.5px 1.5px 0; }

/* ════════════════════════════════════════════════════════
   ORNAMENT — five stars
════════════════════════════════════════════════════════ */
.ornament { text-align:center; padding:1.2rem 0; color:rgba(201,168,76,0.35); font-family:'Cormorant Garamond',serif; font-size:0.9rem; letter-spacing:8px; user-select:none; }

/* ════════════════════════════════════════════════════════
   CARDS / PLACECARDS
════════════════════════════════════════════════════════ */
.grid-3 { display:grid; grid-template-columns:repeat(3,1fr); gap:36px; margin-top:3.5rem; } /* ← DESKTOP CARD GAP */
.grid-2 { display:grid; grid-template-columns:repeat(2,1fr); gap:36px; margin-top:3.5rem; }
.card {
    background: var(--bg2);
    border: 1px solid rgba(201,168,76,0.28); /* ← CARD BORDER */
    padding: 2.8rem 2.2rem;                /* ← CARD PADDING */
    display:flex; flex-direction:column; align-items:center; text-align:center;
    position:relative; overflow:hidden; border-radius:2px;
    transition: background var(--transition), border-color var(--transition), box-shadow var(--transition), transform var(--transition);
}
.card::before { content:''; position:absolute; inset:0; background:radial-gradient(ellipse at 50% 0%, rgba(201,168,76,0.09), transparent 68%); opacity:0.5; pointer-events:none; transition:opacity var(--transition); }
.card:hover { background:var(--bg3); border-color:rgba(201,168,76,0.55); box-shadow:0 0 20px rgba(201,168,76,0.18), inset 0 1px 0 rgba(201,168,76,0.08); transform:translateY(-4px); }
.card:hover::before { opacity:1; }
.card p { flex:1; margin-bottom:0; }
.card .btn { margin-top:1.8rem; }
.card--featured { border-color:var(--gold) !important; box-shadow:0 0 24px rgba(201,168,76,0.18); }

/* ════════════════════════════════════════════════════════
   CONTACT FORM
════════════════════════════════════════════════════════ */
.form-group { margin-bottom:1.4rem; }
.form-group label { display:block; font-family:'Cormorant Garamond',serif; font-size:0.78rem; letter-spacing:0.28em; text-transform:uppercase; color:var(--gold-dim); margin-bottom:0.5rem; font-weight:400; }
.form-group input,
.form-group textarea,
.form-group select {
    width:100%; background:rgba(20,26,38,0.9); /* ← FORM FIELD BG */
    border:1px solid rgba(201,168,76,0.3);      /* ← FORM FIELD BORDER */
    padding:12px 16px;                          /* ← FORM FIELD PADDING */
    border-radius:2px; color:var(--text);
    font-family:'Cormorant Garamond',serif; font-size:1rem; font-weight:300;
    outline:none; transition:border-color var(--transition), box-shadow var(--transition);
}
.form-group input:focus,
.form-group textarea:focus,
.form-group select:focus { border-color:var(--gold); box-shadow:0 0 10px rgba(201,168,76,0.15); }
.form-group textarea { min-height:140px; resize:vertical; }
.form-success { padding:1rem 1.4rem; border:1px solid rgba(201,168,76,0.45); background:rgba(201,168,76,0.06); color:var(--gold-light); font-size:0.95rem; border-radius:2px; margin-top:1rem; }
.form-error   { padding:1rem 1.4rem; border:1px solid rgba(220,80,80,0.4);   background:rgba(220,80,80,0.06);   color:#e4a0a0; font-size:0.95rem; border-radius:2px; margin-top:1rem; }

/* ════════════════════════════════════════════════════════
   SOCIAL ICON BUTTONS
════════════════════════════════════════════════════════ */
.social-row { display:flex; flex-wrap:wrap; gap:0.55rem; margin-top:2.2rem; } /* ← SOCIAL TOP MARGIN */
.social-icon-link {
    display:inline-flex; align-items:center; justify-content:center; gap:0px;
    width:38px; height:38px;               /* ← SOCIAL BUTTON SIZE */
    background:rgba(20,26,38,0.97); border:1px solid rgba(201,168,76,0.45); color:var(--gold-light);
    border-radius:2px; cursor:pointer; text-decoration:none;
    position:relative; overflow:hidden; flex-shrink:0;
    transition:width var(--transition), padding var(--transition), gap var(--transition), border-color var(--transition), background var(--transition), box-shadow var(--transition);
}
.social-icon-link::after { content:''; position:absolute; inset:0; background:radial-gradient(ellipse at 50% 0%, rgba(201,168,76,0.1), transparent 68%); pointer-events:none; }
.social-icon-link svg { width:16px; height:16px; fill:none; stroke:currentColor; stroke-width:1.8; stroke-linecap:round; stroke-linejoin:round; flex-shrink:0; position:relative; z-index:1; }
.social-label { font-family:'Jost',sans-serif; font-size:0.65rem; letter-spacing:0.15em; text-transform:uppercase; font-weight:300; color:var(--gold-dim); opacity:0; width:0; overflow:hidden; white-space:nowrap; transition:opacity var(--transition), width var(--transition); position:relative; z-index:1; }

.social-icon-link:hover {
    width: auto;
    padding: 0 12px;
    gap: 8px;
    border-color: rgba(201,168,76,0.7);
    box-shadow: 0 0 14px rgba(201,168,76,0.2);
}
.social-icon-link:hover .social-label { opacity:1; width:auto; }

/* ════════════════════════════════════════════════════════
   18+ ADULT BANNER
════════════════════════════════════════════════════════ */
#adult-cookie-banner { position:fixed; bottom:0; left:0; width:100%; background:rgba(18,22,32,0.97); border-top:1px solid rgba(201,168,76,0.55); z-index:99999; padding:1.6rem 5%; display:flex; justify-content:space-between; align-items:center; gap:2rem; box-shadow:0 -8px 40px rgba(0,0,0,0.7); transition:transform 0.45s ease, opacity 0.45s ease; backdrop-filter:blur(14px); }
.banner-text { font-family:'Jost',sans-serif; font-size:0.8rem; color:var(--text-muted); line-height:1.6; font-weight:300; }
.banner-text strong { font-weight:400; color:var(--gold-light); }
.banner-text a { color:var(--blue); text-decoration:underline; }
.banner-buttons { display:flex; gap:10px; flex-shrink:0; }

/* ════════════════════════════════════════════════════════
   CHAT POPUP
════════════════════════════════════════════════════════ */
#timed-chat-popup { position:fixed; bottom:120px; right:90px; width:320px; background:rgba(20,26,38,0.97); border:1px solid rgba(201,168,76,0.55); box-shadow:0 16px 50px rgba(0,0,0,0.7); z-index:9998; padding:2rem 1.8rem 1.6rem; opacity:0; visibility:hidden; transform:translateY(20px); transition:all 0.5s cubic-bezier(0.16,1,0.3,1); backdrop-filter:blur(16px); border-radius:2px; }
#timed-chat-popup::before { content:''; position:absolute; top:0; left:10%; right:10%; height:1px; background:linear-gradient(to right, transparent, var(--gold-light), transparent); }
#timed-chat-popup::after  { content:''; position:absolute; inset:0; background:radial-gradient(ellipse at 50% 0%, rgba(201,168,76,0.08), transparent 65%); pointer-events:none; }
#timed-chat-popup.show { opacity:1; visibility:visible; transform:translateY(0); }
.popup-close   { position:absolute; top:12px; right:14px; color:var(--text-muted); cursor:pointer; font-family:'Cormorant Garamond',serif; font-size:0.85rem; letter-spacing:1px; transition:color var(--transition); z-index:10; }
.popup-close:hover { color:var(--gold-light); }
.popup-eyebrow { font-family:'Cormorant Garamond',serif; font-size:0.62rem; letter-spacing:0.35em; text-transform:uppercase; color:var(--gold-dim); margin-bottom:0.5rem; opacity:0.85; position:relative; z-index:1; }
.popup-title   { font-family:'Pinyon Script',cursive; color:var(--gold-light); font-size:2rem; font-weight:400; margin-bottom:0.6rem; line-height:1.2; position:relative; z-index:1; }
.popup-text    { font-size:0.82rem; color:var(--text-muted); margin-bottom:1.3rem; font-weight:300; line-height:1.7; position:relative; z-index:1; font-family:'Jost',sans-serif; }
.popup-text strong { color:var(--text); font-weight:400; }

/* ════════════════════════════════════════════════════════
   SCROLL TO TOP
════════════════════════════════════════════════════════ */
#scroll-top-btn { position:fixed; bottom:100px; right:32px; width:46px; height:46px; background:rgba(20,26,38,0.97); border:1px solid rgba(201,168,76,0.4); color:var(--text-muted); border-radius:2px; cursor:pointer; z-index:9997; display:flex; align-items:center; justify-content:center; opacity:0; visibility:hidden; transition:border-color var(--transition), color var(--transition), background var(--transition), opacity var(--transition), visibility var(--transition), box-shadow var(--transition); }
#scroll-top-btn.visible { opacity:1; visibility:visible; }
#scroll-top-btn svg { width:20px; height:20px; transition:transform var(--transition); }
#scroll-top-btn:hover { border-color:var(--gold); color:var(--gold-light); box-shadow:0 0 10px rgba(201,168,76,0.25); }
#scroll-top-btn:hover svg { transform:translateY(-2px); }

/* ════════════════════════════════════════════════════════
   FOOTER
════════════════════════════════════════════════════════ */
footer { background:var(--bg); padding:6rem 0 3rem; position:relative; }
footer::before { content:''; position:absolute; top:0; left:0; right:0; height:1px; background:linear-gradient(to right, rgba(201,168,76,0) 0%, rgba(201,168,76,0.06) 8%, rgba(228,201,123,0.75) 50%, rgba(201,168,76,0.06) 92%, rgba(201,168,76,0) 100%); box-shadow:0 0 12px rgba(201,168,76,0.12); }
.footer-inner { display:grid; grid-template-columns:2fr 1fr 1fr; gap:0; margin-bottom:4rem; }
.footer-col-left   { padding-right:8rem; }  /* ← double gap left→middle */
.footer-col-middle { padding-right:4rem; }  /* ← single gap middle→right */
.footer-brand { display:flex; align-items:center; gap:10px; margin-bottom:1.2rem; }
.footer-logo-img       { width:28px; height:28px; object-fit:contain; display:block; }
.footer-logo-fallback  { display:none; width:22px; height:22px; stroke:var(--gold-light); fill:none; stroke-width:1.2; }
.footer-brand-name     { font-family:'Pinyon Script',cursive; font-size:2rem; color:var(--gold-light); text-shadow:0 1px 8px rgba(201,168,76,0.25); letter-spacing:0.03em; text-decoration:none; }
.footer-about          { font-family:'Cormorant Garamond',serif; font-size:1rem; color:var(--text-muted); line-height:1.8; font-weight:300; max-width:340px; }
.footer-heading        { font-family:'Cormorant Garamond',serif; font-style:italic; font-size:1.1rem; color:var(--text); margin-bottom:1.3rem; letter-spacing:0.03em; }
.footer-links          { list-style:none; }
.footer-links li       { margin-bottom:0.65rem; }
.footer-links a        { font-family:'Cormorant Garamond',serif; font-size:1rem; color:var(--text-muted); transition:color var(--transition), padding-left var(--transition); font-weight:300; }
.footer-links a:hover  { color:var(--gold-light); padding-left:4px; }
.footer-bottom         { border-top:1px solid rgba(255,255,255,0.05); padding-top:2rem; display:flex; justify-content:space-between; align-items:center; }
.footer-copy           { font-family:'Jost',sans-serif; font-size:0.78rem; color:var(--text-faint); }
.footer-legal          { display:flex; gap:2rem; }
.footer-legal a        { font-family:'Jost',sans-serif; font-size:0.78rem; color:var(--text-faint); transition:color var(--transition); }
.footer-legal a:hover  { color:var(--gold-light); }

/* ════════════════════════════════════════════════════════
   PAGE-SPECIFIC — About
════════════════════════════════════════════════════════ */
.about-intro { max-width:760px; margin:0 auto 4rem; text-align:center; }
.values-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:2rem; margin-top:3rem; }
.value-item  { text-align:center; padding:2rem 1.5rem; border:1px solid rgba(201,168,76,0.15); background:var(--bg2); }
.value-icon  { font-size:1.6rem; color:var(--gold); margin-bottom:0.8rem; }

/* ════════════════════════════════════════════════════════
   PAGE-SPECIFIC — Services
════════════════════════════════════════════════════════ */
.service-detail { display:grid; grid-template-columns:1fr 1fr; gap:4rem; align-items:start; margin-bottom:6rem; }
.service-detail:last-child { margin-bottom:0; }

/* ════════════════════════════════════════════════════════
   PAGE-SPECIFIC — Pricing
════════════════════════════════════════════════════════ */
.price-amount   { font-family:'Pinyon Script',cursive; font-size:3rem; color:var(--gold-light); line-height:1; margin:0.5rem 0; }
.price-period   { font-family:'Jost',sans-serif; font-size:0.72rem; letter-spacing:0.2em; text-transform:uppercase; color:var(--gold-dim); }
.price-divider  { width:40px; height:1px; background:rgba(201,168,76,0.35); margin:1.2rem auto; }
.price-features { list-style:none; margin-bottom:1.5rem; text-align:left; }
.price-features li { font-size:1rem; color:var(--text-muted); padding:0.35rem 0; border-bottom:1px solid rgba(255,255,255,0.04); }
.price-features li:last-child { border-bottom:none; }
.price-features li::before { content:'·'; color:var(--gold-dim); margin-right:0.5rem; }

/* ════════════════════════════════════════════════════════
   PAGE-SPECIFIC — Contact
════════════════════════════════════════════════════════ */
.contact-grid { display:grid; grid-template-columns:1fr 1.4fr; gap:5rem; align-items:start; }
.contact-info-item { display:flex; align-items:flex-start; gap:1rem; margin-bottom:1.5rem; }
.contact-info-icon { width:38px; height:38px; flex-shrink:0; background:var(--bg2); border:1px solid rgba(201,168,76,0.3); display:flex; align-items:center; justify-content:center; border-radius:2px; }
.contact-info-icon svg { width:16px; height:16px; fill:none; stroke:var(--gold-light); stroke-width:1.8; stroke-linecap:round; stroke-linejoin:round; }

/* ════════════════════════════════════════════════════════
   UTILITY
════════════════════════════════════════════════════════ */
.text-center { text-align:center; }
.text-gold   { color:var(--gold-light); -webkit-text-fill-color:var(--gold-light); }
.mt-0 { margin-top:0 !important; } .mt-1 { margin-top:1rem; } .mt-2 { margin-top:2rem; }
.mb-0 { margin-bottom:0 !important; } .mb-1 { margin-bottom:1rem; } .mb-2 { margin-bottom:2rem; }
.hidden { display:none !important; }

/* ════════════════════════════════════════════════════════
   RESPONSIVE — TABLET ≤ 1080px
════════════════════════════════════════════════════════ */
@media (max-width: 1080px) {
    .grid-3, .grid-2 { grid-template-columns:1fr; gap:24px; }
    .values-grid { grid-template-columns:1fr 1fr; }
    .service-detail { grid-template-columns:1fr; gap:3rem; }
    .contact-grid { grid-template-columns:1fr; gap:3rem; }
    .footer-inner { grid-template-columns:1fr 1fr; gap:3rem 4rem; }
    .footer-col-left { grid-column:1 / -1; padding-right:0; }
    .footer-col-middle { padding-right:0; }
    h2.section-title { white-space:normal !important; }
}

/* ════════════════════════════════════════════════════════
   RESPONSIVE — MOBILE ≤ 968px
════════════════════════════════════════════════════════ */
@media (max-width: 968px) {
    .split { grid-template-columns:1fr; gap:3.5rem; }
    .split .img-frame { order:-1; max-width:100%; }
    .hero { padding-top:160px; padding-bottom:80px; min-height:auto; }
    .page-hero { padding-top:150px; padding-bottom:4rem; }
    .section-pad { padding:5.5rem 0; }
    .values-grid { grid-template-columns:1fr; }
    .footer-inner { grid-template-columns:1fr; gap:2.5rem; }
    .footer-col-left, .footer-col-middle { padding-right:0; }
    .footer-bottom { flex-direction:column; gap:1rem; text-align:center; }
    .footer-legal { justify-content:center; }
    .menu-icon { display:block; color:var(--gold-light); font-size:1.6rem; cursor:pointer; z-index:20; position:relative; user-select:none; }
    nav ul { display:none; flex-direction:column; position:absolute; top:100%; left:-5%; width:110vw; background:rgba(18,22,32,0.98); padding:2.5rem 8%; border-bottom:1px solid rgba(201,168,76,0.2); gap:1.6rem; backdrop-filter:blur(16px); }
    #menu-toggle:checked ~ ul { display:flex; }
    #timed-chat-popup { width:90%; max-width:310px; bottom:130px; right:auto; left:50%; transform:translateX(-50%); }
    #timed-chat-popup.show { transform:translateX(-50%); }
    #scroll-top-btn { bottom:95px; right:26px; width:42px; height:42px; }
    .grid-3, .grid-2 { grid-template-columns:1fr; gap:28px; max-width:360px; margin-left:auto; margin-right:auto; }
    .card { padding:2rem 1.6rem; }
    /* 18+ banner — text on top, buttons in a row below */
    #adult-cookie-banner { flex-direction:column; align-items:stretch; padding:1.2rem 5%; gap:0.8rem; }
    .banner-buttons { flex-direction:row; justify-content:center; flex-wrap:wrap; gap:8px; }
    h2.section-title { font-size:clamp(2rem, 7vw, 2.8rem); }
    .social-icon-link { width:auto; padding:0 10px; }
    .social-label { opacity:1; width:auto; overflow:visible; }
    .contact-grid { grid-template-columns:1fr; gap:3rem; }
}
@media (max-width: 600px) { .footer-inner { gap:2rem; } }
