<style>
/* ============================================================
   Golf Post Homepage Facelift v5 — 5-Tab Concierge + Spotify Freemium
   Three tiers: Anonymous (3 queries, locked CTAs) / Free (10/mo) / Premium (unlimited)
   ============================================================ */

/* -- Reset & Tokens -- */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

:root {
    --gp-green: #04AE79;
    --gp-green-dark: #039768;
    --gp-green-tint: rgba(4,174,121,0.08);
    --gp-red: #EE3F34;
    --gp-gold: #FFB300;
    --gp-dark: #2c2c2c;
    --gp-darker: #1a1a1a;
    --gp-bg: #f5f5f5;
    --gp-bg-card: #ffffff;
    --gp-border: #e5e5e5;
    --gp-text: #1a1a1a;
    --gp-text-secondary: #555;
    --gp-text-muted: #888;
    --gp-font: -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif;
    --gp-radius: 8px;
    --gp-radius-sm: 6px;
    --gp-shadow: 0 1px 4px rgba(0,0,0,0.08);
    --gp-shadow-lg: 0 4px 16px rgba(0,0,0,0.10);
    --gp-max-width: 1200px;
    --gp-transition: 0.2s ease;
}

body {
    font-family: var(--gp-font);
    color: var(--gp-text);
    background: var(--gp-bg);
    -webkit-font-smoothing: antialiased;
    line-height: 1.5;
    font-size: 15px;
}

a { color: var(--gp-green); text-decoration: none; }
a:hover { text-decoration: underline; }
img { max-width: 100%; height: auto; display: block; }

.container {
    max-width: var(--gp-max-width);
    margin: 0 auto;
    padding: 0 16px;
}

/* -- View Toggle -- */
.view-toggle {
    position: fixed;
    top: 12px;
    right: 16px;
    z-index: 1000;
    display: flex;
    background: #fff;
    border-radius: 24px;
    box-shadow: var(--gp-shadow-lg);
    overflow: hidden;
    border: 2px solid var(--gp-green);
}
.view-toggle__btn {
    padding: 8px 16px;
    font-size: 13px;
    font-weight: 600;
    border: none;
    cursor: pointer;
    background: #fff;
    color: var(--gp-green);
    transition: var(--gp-transition);
    font-family: var(--gp-font);
}
.view-toggle__btn.active {
    background: var(--gp-green);
    color: #fff;
}
.view-toggle__btn:hover:not(.active) {
    background: var(--gp-green-tint);
}

.hidden { display: none !important; }

/* ============================================================
   HEADER
   ============================================================ */
.top-bar {
    background: #fff;
    border-bottom: 1px solid var(--gp-border);
    font-size: 12px;
    color: var(--gp-text-muted);
}
.top-bar__inner {
    display: flex;
    justify-content: flex-end;
    align-items: center;
    height: 32px;
    gap: 16px;
}
.top-bar__link { color: var(--gp-text-muted); font-size: 12px; }
.top-bar__link:hover { color: var(--gp-text); text-decoration: none; }
.top-bar__social { display: flex; gap: 12px; }
.top-bar__social a { color: var(--gp-text-muted); font-size: 14px; }
.top-bar__social a:hover { color: var(--gp-green); }

@media (max-width: 767px) {
    .top-bar { display: none; }
}

.site-header {
    background: #fff;
    border-bottom: 1px solid var(--gp-border);
    position: sticky;
    top: 0;
    z-index: 900;
}
.site-header__inner {
    display: flex;
    align-items: center;
    height: 56px;
    gap: 24px;
}
.site-header__logo {
    display: flex;
    align-items: center;
    gap: 8px;
    flex-shrink: 0;
}
.site-header__logo-img {
    height: 22px;
    width: auto;
}
.site-header__logo-text {
    font-size: 22px;
    font-weight: 800;
    color: var(--gp-text);
    letter-spacing: -0.5px;
    white-space: nowrap;
}
.site-header__logo-text span { color: var(--gp-green); }

@media (max-width: 767px) {
    .site-header__logo-img { height: 20px; }
}

/* Search in header */
.site-header__search {
    flex: 1;
    max-width: 320px;
    position: relative;
}
.site-header__search-input {
    width: 100%;
    padding: 8px 14px 8px 36px;
    border: 1.5px solid var(--gp-border);
    border-radius: 20px;
    font-size: 14px;
    font-family: var(--gp-font);
    background: var(--gp-bg);
    outline: none;
    transition: border-color var(--gp-transition);
}
.site-header__search-input:focus {
    border-color: var(--gp-green);
    background: #fff;
}
.site-header__search-input::placeholder { color: var(--gp-text-muted); }
.site-header__search-icon {
    position: absolute;
    left: 12px;
    top: 50%;
    transform: translateY(-50%);
    color: var(--gp-text-muted);
    font-size: 14px;
    pointer-events: none;
}

@media (max-width: 767px) {
    .site-header__search { display: none; }
}

.site-header__extras {
    margin-left: auto;
    display: flex;
    align-items: center;
    gap: 16px;
}
.site-header__extra-link {
    color: var(--gp-text-secondary);
    font-size: 13px;
    white-space: nowrap;
    display: flex;
    align-items: center;
    gap: 4px;
}
.site-header__extra-link:hover { color: var(--gp-green); text-decoration: none; }
.site-header__search-mobile {
    display: none;
    color: var(--gp-text-secondary);
    font-size: 18px;
    background: none;
    border: none;
    cursor: pointer;
    padding: 4px;
}
@media (max-width: 900px) {
    .site-header__extras .desktop-link { display: none; }
}
@media (max-width: 767px) {
    .site-header__search-mobile { display: flex; }
}

/* Concierge icon in header */
.site-header__concierge-btn {
    display: flex;
    align-items: center;
    gap: 5px;
    background: linear-gradient(135deg, var(--gp-green), #2B7860);
    color: #fff;
    border: none;
    border-radius: 20px;
    padding: 6px 14px;
    font-size: 13px;
    font-weight: 600;
    cursor: pointer;
    font-family: var(--gp-font);
    transition: all var(--gp-transition);
    white-space: nowrap;
}
.site-header__concierge-btn:hover {
    background: linear-gradient(135deg, #2B7860, var(--gp-green-dark));
    transform: translateY(-1px);
}
.site-header__concierge-btn .sparkle {
    font-size: 15px;
    animation: sparkle-rotate 3s ease-in-out infinite;
}
@keyframes sparkle-rotate {
    0%, 100% { transform: rotate(0deg) scale(1); }
    25% { transform: rotate(15deg) scale(1.15); }
    50% { transform: rotate(0deg) scale(1); }
    75% { transform: rotate(-15deg) scale(1.15); }
}
@media (max-width: 767px) {
    .site-header__concierge-btn span:not(.sparkle) { display: none; }
    .site-header__concierge-btn { padding: 6px 10px; }
}

/* Green nav bar */
.nav-bar { background: var(--gp-green); }
.nav-bar__inner {
    display: flex;
    align-items: center;
    height: 44px;
    gap: 0;
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
    scrollbar-width: none;
}
.nav-bar__inner::-webkit-scrollbar { display: none; }
.nav-bar__link {
    color: #fff;
    font-size: 14px;
    font-weight: 600;
    padding: 0 14px;
    height: 44px;
    display: flex;
    align-items: center;
    white-space: nowrap;
    transition: background var(--gp-transition);
    text-decoration: none;
}
.nav-bar__link:hover { background: rgba(0,0,0,0.1); text-decoration: none; }
.nav-bar__link--active { background: rgba(0,0,0,0.15); }
.nav-bar__hamburger {
    display: none;
    background: none;
    border: none;
    color: #fff;
    font-size: 22px;
    padding: 0 12px;
    cursor: pointer;
    height: 44px;
    align-items: center;
}
@media (max-width: 767px) {
    .nav-bar__hamburger { display: flex; }
    .nav-bar__link.desktop-only { display: none; }
}

/* ============================================================
   PROMO BAR
   ============================================================ */
.promo-bar {
    background: linear-gradient(135deg, var(--gp-green), var(--gp-green-dark));
    color: #fff;
    text-align: center;
    padding: 10px 16px;
    font-size: 14px;
    font-weight: 600;
}
.promo-bar a { color: #fff; text-decoration: underline; }
.promo-bar--welcome { background: linear-gradient(135deg, #2B7860, #1a5a45); }

/* ============================================================
   STORIES RING
   ============================================================ */
.stories {
    padding: 16px 0 8px;
    background: #fff;
    border-bottom: 1px solid var(--gp-border);
}
.stories__scroll {
    display: flex;
    gap: 16px;
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
    padding: 4px 0 8px;
    scrollbar-width: none;
}
.stories__scroll::-webkit-scrollbar { display: none; }
.story {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 6px;
    flex-shrink: 0;
    cursor: pointer;
    min-width: 72px;
}
.story__ring {
    width: 64px;
    height: 64px;
    border-radius: 50%;
    padding: 3px;
    background: linear-gradient(135deg, var(--gp-green), #2B7860, var(--gp-green-dark));
}
.story__ring--live {
    background: linear-gradient(135deg, var(--gp-red), #ff6b6b, var(--gp-red));
    animation: pulse-ring 2s infinite;
}
@keyframes pulse-ring {
    0%, 100% { box-shadow: 0 0 0 0 rgba(238,63,52,0.3); }
    50% { box-shadow: 0 0 0 4px rgba(238,63,52,0); }
}
.story__ring--gold {
    background: linear-gradient(135deg, var(--gp-gold), #ff9800, var(--gp-gold));
}
.story__avatar {
    width: 100%;
    height: 100%;
    border-radius: 50%;
    border: 2px solid #fff;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 20px;
    font-weight: 700;
    color: #fff;
}
.story__avatar--pga { background: linear-gradient(135deg, #1a3a6c, #2563eb); }
.story__avatar--dpw { background: linear-gradient(135deg, #1e3a5f, #4a90d9); }
.story__avatar--liv { background: linear-gradient(135deg, #1a1a1a, #444); }
.story__avatar--equip { background: linear-gradient(135deg, #1565C0, #42a5f5); }
.story__avatar--training { background: linear-gradient(135deg, var(--gp-green-dark), var(--gp-green)); }
.story__avatar--ladies { background: linear-gradient(135deg, #9c27b0, #ce93d8); }
.story__avatar--travel { background: linear-gradient(135deg, #e67e22, #f39c12); }
.story__avatar--premium { background: linear-gradient(135deg, #1a3a2a, var(--gp-green-dark)); }
.story__avatar--community { background: linear-gradient(135deg, #00897b, #4db6ac); }
.story__avatar--amateur { background: linear-gradient(135deg, #558b2f, #8bc34a); }
.story__label {
    font-size: 11px;
    color: var(--gp-text-secondary);
    text-align: center;
    max-width: 72px;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

/* ============================================================
   HERO SECTION
   ============================================================ */
.hero { padding: 20px 0; }
.hero__grid {
    display: grid;
    grid-template-columns: 2fr 1fr;
    grid-template-rows: auto auto;
    gap: 12px;
}
.hero__main { grid-row: 1 / 3; min-height: 360px; }
.hero__side { min-height: 172px; }
.hero__card {
    position: relative;
    border-radius: var(--gp-radius);
    overflow: hidden;
    display: flex;
    flex-direction: column;
    justify-content: flex-end;
    cursor: pointer;
    transition: transform var(--gp-transition);
}
.hero__card:hover { transform: translateY(-2px); }
.hero__card-bg {
    position: absolute;
    inset: 0;
    background-size: cover;
    background-position: center;
}
.hero__card-overlay {
    position: absolute;
    inset: 0;
    background: linear-gradient(to top, rgba(0,0,0,0.7) 0%, rgba(0,0,0,0.1) 60%);
}
.hero__card-content {
    position: relative;
    padding: 20px;
    color: #fff;
    z-index: 1;
}
.hero__card-badge {
    display: inline-block;
    background: var(--gp-red);
    color: #fff;
    font-size: 11px;
    font-weight: 700;
    text-transform: uppercase;
    padding: 3px 8px;
    border-radius: 3px;
    margin-bottom: 8px;
    letter-spacing: 0.5px;
}
.hero__card-badge--live {
    background: var(--gp-red);
    animation: pulse-badge 2s infinite;
}
@keyframes pulse-badge {
    0%, 100% { opacity: 1; }
    50% { opacity: 0.7; }
}
.hero__card-title {
    font-size: 26px;
    font-weight: 700;
    line-height: 1.2;
    text-shadow: 0 1px 4px rgba(0,0,0,0.3);
}
.hero__side .hero__card-title { font-size: 16px; }
.hero__card-meta {
    font-size: 13px;
    color: rgba(255,255,255,0.8);
    margin-top: 6px;
}

@media (max-width: 767px) {
    .hero__grid {
        grid-template-columns: 1fr;
        grid-template-rows: auto;
    }
    .hero__main { min-height: 240px; grid-row: auto; }
    .hero__side { min-height: 160px; }
    .hero__card-title { font-size: 20px; }
    .hero__side .hero__card-title { font-size: 16px; }
}

/* ============================================================
   SECTION BASE
   ============================================================ */
.section { padding: 32px 0; }
.section--alt { background: #fff; }
.section__header {
    display: flex;
    justify-content: space-between;
    align-items: baseline;
    margin-bottom: 16px;
}
.section__title {
    font-size: 20px;
    font-weight: 700;
    color: var(--gp-text);
}
.section__link {
    font-size: 13px;
    font-weight: 600;
    color: var(--gp-green);
    white-space: nowrap;
}

/* ============================================================
   AD SLOTS
   ============================================================ */
.ad-slot {
    background: #e8e8e8;
    border: 1px dashed #ccc;
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--gp-text-muted);
    font-size: 12px;
    text-transform: uppercase;
    letter-spacing: 1px;
    margin: 0 auto;
}
.ad-slot--leaderboard { width: 728px; max-width: 100%; height: 90px; }
.ad-slot--rectangle { width: 300px; height: 250px; }
.ad-slot--mobile-banner { width: 320px; max-width: 100%; height: 50px; display: none; }
@media (max-width: 767px) {
    .ad-slot--leaderboard { display: none; }
    .ad-slot--mobile-banner { display: flex; }
}
.ad-wrapper { padding: 16px 0; text-align: center; }
.ad-wrapper__label {
    font-size: 10px;
    color: var(--gp-text-muted);
    text-transform: uppercase;
    letter-spacing: 1px;
    margin-bottom: 4px;
}

/* ============================================================
   AI CONCIERGE SECTION
   ============================================================ */
.concierge {
    background: linear-gradient(180deg, #0f1f18 0%, #162920 40%, #0d1f16 100%);
    padding: 48px 0 56px;
    position: relative;
    overflow: hidden;
}
.concierge::before {
    content: '';
    position: absolute;
    top: -100px;
    right: -100px;
    width: 400px;
    height: 400px;
    background: radial-gradient(circle, rgba(4,174,121,0.12) 0%, transparent 70%);
    pointer-events: none;
}
.concierge::after {
    content: '';
    position: absolute;
    bottom: -80px;
    left: -80px;
    width: 300px;
    height: 300px;
    background: radial-gradient(circle, rgba(4,174,121,0.08) 0%, transparent 70%);
    pointer-events: none;
}
.concierge__header {
    text-align: center;
    margin-bottom: 32px;
    position: relative;
    z-index: 1;
}
.concierge__badge {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    background: rgba(4,174,121,0.15);
    border: 1px solid rgba(4,174,121,0.3);
    color: var(--gp-green);
    font-size: 12px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 1px;
    padding: 6px 16px;
    border-radius: 20px;
    margin-bottom: 16px;
}
.concierge__badge .sparkle { animation: sparkle-rotate 3s ease-in-out infinite; }
.concierge__title {
    font-size: 32px;
    font-weight: 800;
    color: #fff;
    margin-bottom: 10px;
    line-height: 1.2;
}
@media (max-width: 767px) { .concierge__title { font-size: 24px; } }
.concierge__subtitle {
    font-size: 16px;
    color: rgba(255,255,255,0.65);
    max-width: 640px;
    margin: 0 auto;
    line-height: 1.6;
}

/* Concierge Tabs */
.concierge__tabs {
    display: flex;
    justify-content: center;
    gap: 8px;
    margin-bottom: 24px;
    position: relative;
    z-index: 1;
}
.concierge__tab {
    padding: 10px 24px;
    border-radius: 24px;
    font-size: 14px;
    font-weight: 600;
    border: 1.5px solid rgba(255,255,255,0.15);
    color: rgba(255,255,255,0.7);
    background: rgba(255,255,255,0.05);
    cursor: pointer;
    transition: all var(--gp-transition);
    font-family: var(--gp-font);
    display: flex;
    align-items: center;
    gap: 6px;
}
.concierge__tab:hover {
    border-color: rgba(4,174,121,0.5);
    color: #fff;
    background: rgba(4,174,121,0.1);
}
.concierge__tab.active {
    border-color: var(--gp-green);
    color: #fff;
    background: rgba(4,174,121,0.2);
}
.concierge__tab-icon { font-size: 16px; }

/* Concierge Input Area */
.concierge__input-area {
    max-width: 680px;
    margin: 0 auto 20px;
    position: relative;
    z-index: 1;
}
.concierge__input-wrap {
    display: flex;
    background: rgba(255,255,255,0.08);
    border: 1.5px solid rgba(255,255,255,0.15);
    border-radius: 28px;
    overflow: hidden;
    transition: border-color var(--gp-transition);
}
.concierge__input-wrap:focus-within {
    border-color: var(--gp-green);
    background: rgba(255,255,255,0.12);
}
.concierge__input {
    flex: 1;
    padding: 14px 20px;
    background: transparent;
    border: none;
    outline: none;
    color: #fff;
    font-size: 15px;
    font-family: var(--gp-font);
}
.concierge__input::placeholder { color: rgba(255,255,255,0.4); }
.concierge__send {
    background: var(--gp-green);
    border: none;
    color: #fff;
    padding: 14px 24px;
    font-size: 14px;
    font-weight: 700;
    cursor: pointer;
    font-family: var(--gp-font);
    transition: background var(--gp-transition);
    white-space: nowrap;
}
.concierge__send:hover { background: var(--gp-green-dark); }

/* Concierge Chips */
.concierge__chips {
    display: flex;
    justify-content: center;
    gap: 8px;
    flex-wrap: wrap;
    margin-bottom: 32px;
    position: relative;
    z-index: 1;
}
.concierge__chip {
    padding: 8px 16px;
    border-radius: 20px;
    font-size: 13px;
    font-weight: 500;
    border: 1px solid rgba(255,255,255,0.12);
    color: rgba(255,255,255,0.7);
    background: rgba(255,255,255,0.04);
    cursor: pointer;
    transition: all var(--gp-transition);
    font-family: var(--gp-font);
}
.concierge__chip:hover {
    border-color: var(--gp-green);
    color: #fff;
    background: rgba(4,174,121,0.1);
    transform: translateY(-1px);
}

/* Chat Window */
.concierge__chat {
    max-width: 720px;
    margin: 0 auto;
    position: relative;
    z-index: 1;
    min-height: 0;
    transition: min-height 0.4s ease;
}
.concierge__chat.active { min-height: 200px; }
.chat-conversation { display: none; }
.chat-conversation.active { display: block; animation: chatFadeIn 0.4s ease; }
@keyframes chatFadeIn {
    from { opacity: 0; transform: translateY(10px); }
    to { opacity: 1; transform: translateY(0); }
}

/* Chat Messages */
.chat-msg {
    display: flex;
    gap: 10px;
    margin-bottom: 16px;
    opacity: 0;
    transform: translateY(8px);
    animation: msgAppear 0.4s ease forwards;
}
.chat-msg:nth-child(1) { animation-delay: 0s; }
.chat-msg:nth-child(2) { animation-delay: 0.8s; }
.chat-msg:nth-child(3) { animation-delay: 1.2s; }
.chat-msg:nth-child(4) { animation-delay: 2.8s; }
.chat-msg:nth-child(5) { animation-delay: 4.4s; }
.chat-msg:nth-child(6) { animation-delay: 5.6s; }
@keyframes msgAppear {
    to { opacity: 1; transform: translateY(0); }
}
.chat-msg--user { justify-content: flex-end; }
.chat-msg--user .chat-bubble {
    background: var(--gp-green);
    color: #fff;
    border-radius: 16px 16px 4px 16px;
}
.chat-avatar {
    width: 32px;
    height: 32px;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 14px;
    flex-shrink: 0;
}
.chat-avatar--ai {
    background: linear-gradient(135deg, var(--gp-green), #2B7860);
    color: #fff;
    font-weight: 700;
}
.chat-avatar--user {
    background: rgba(255,255,255,0.15);
    color: #fff;
    order: 1;
}
.chat-bubble {
    background: rgba(255,255,255,0.08);
    border: 1px solid rgba(255,255,255,0.1);
    color: rgba(255,255,255,0.9);
    padding: 12px 16px;
    border-radius: 16px 16px 16px 4px;
    font-size: 14px;
    line-height: 1.5;
    max-width: 85%;
}

/* Typing indicator */
.chat-typing {
    display: flex;
    gap: 4px;
    padding: 12px 16px;
}
.chat-typing-dot {
    width: 7px;
    height: 7px;
    border-radius: 50%;
    background: var(--gp-green);
    animation: typingBounce 1.4s infinite;
}
.chat-typing-dot:nth-child(2) { animation-delay: 0.2s; }
.chat-typing-dot:nth-child(3) { animation-delay: 0.4s; }
@keyframes typingBounce {
    0%, 60%, 100% { transform: translateY(0); opacity: 0.4; }
    30% { transform: translateY(-6px); opacity: 1; }
}

/* Recommendation Cards in Chat */
.chat-reco-cards {
    display: flex;
    gap: 12px;
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
    padding: 4px 0 8px;
    scrollbar-width: none;
    margin: 4px 0 8px;
}
.chat-reco-cards::-webkit-scrollbar { display: none; }
.chat-reco-card {
    background: rgba(255,255,255,0.06);
    border: 1px solid rgba(255,255,255,0.12);
    border-radius: 12px;
    min-width: 260px;
    max-width: 280px;
    flex-shrink: 0;
    overflow: hidden;
    transition: all var(--gp-transition);
    cursor: pointer;
}
.chat-reco-card:hover {
    border-color: var(--gp-green);
    background: rgba(4,174,121,0.08);
    transform: translateY(-2px);
}
.chat-reco-card__image {
    height: 110px;
    background-size: cover;
    background-position: center;
    position: relative;
}
.chat-reco-card__match {
    position: absolute;
    top: 8px;
    right: 8px;
    background: var(--gp-green);
    color: #fff;
    font-size: 11px;
    font-weight: 700;
    padding: 3px 8px;
    border-radius: 10px;
}
.chat-reco-card__body { padding: 12px; }
.chat-reco-card__name {
    font-size: 15px;
    font-weight: 700;
    color: #fff;
    margin-bottom: 4px;
}
.chat-reco-card__meta {
    font-size: 12px;
    color: rgba(255,255,255,0.5);
    margin-bottom: 8px;
    line-height: 1.4;
}
.chat-reco-card__details {
    font-size: 12px;
    color: rgba(255,255,255,0.7);
    line-height: 1.5;
    margin-bottom: 10px;
}
.chat-reco-card__footer {
    display: flex;
    justify-content: space-between;
    align-items: center;
}
.chat-reco-card__price {
    font-size: 16px;
    font-weight: 700;
    color: var(--gp-green);
}
.chat-reco-card__price span {
    font-size: 11px;
    font-weight: 400;
    color: rgba(255,255,255,0.5);
}
.chat-reco-card__rating {
    font-size: 12px;
    color: var(--gp-gold);
    font-weight: 600;
}
.chat-reco-card__actions {
    display: flex;
    gap: 6px;
    margin-top: 8px;
}
.chat-reco-card__btn {
    padding: 6px 12px;
    border-radius: 6px;
    font-size: 12px;
    font-weight: 600;
    border: none;
    cursor: pointer;
    font-family: var(--gp-font);
    transition: all var(--gp-transition);
}
.chat-reco-card__btn--primary {
    background: var(--gp-green);
    color: #fff;
}
.chat-reco-card__btn--primary:hover { background: var(--gp-green-dark); }
.chat-reco-card__btn--secondary {
    background: rgba(255,255,255,0.1);
    color: rgba(255,255,255,0.8);
    border: 1px solid rgba(255,255,255,0.15);
}
.chat-reco-card__btn--secondary:hover {
    background: rgba(255,255,255,0.15);
    color: #fff;
}

/* Concierge data trust line */
.concierge__trust {
    text-align: center;
    margin-top: 24px;
    position: relative;
    z-index: 1;
}
.concierge__trust-text {
    font-size: 12px;
    color: rgba(255,255,255,0.35);
    display: flex;
    justify-content: center;
    gap: 20px;
    flex-wrap: wrap;
}
.concierge__trust-item {
    display: flex;
    align-items: center;
    gap: 4px;
}

/* ============================================================
   CONCIERGE MODAL (Header mini version)
   ============================================================ */
.concierge-modal-overlay {
    display: none;
    position: fixed;
    inset: 0;
    background: rgba(0,0,0,0.6);
    z-index: 2000;
    align-items: center;
    justify-content: center;
    padding: 20px;
}
.concierge-modal-overlay.active { display: flex; }
.concierge-modal {
    background: #0f1f18;
    border: 1px solid rgba(4,174,121,0.3);
    border-radius: 16px;
    width: 100%;
    max-width: 700px;
    max-height: 80vh;
    overflow-y: auto;
    padding: 28px 24px;
    position: relative;
}
.concierge-modal__close {
    position: absolute;
    top: 12px;
    right: 16px;
    background: none;
    border: none;
    color: rgba(255,255,255,0.5);
    font-size: 24px;
    cursor: pointer;
    transition: color var(--gp-transition);
}
.concierge-modal__close:hover { color: #fff; }
.concierge-modal__title {
    font-size: 20px;
    font-weight: 700;
    color: #fff;
    margin-bottom: 16px;
    display: flex;
    align-items: center;
    gap: 8px;
}

/* ============================================================
   LIVE SCORES
   ============================================================ */
.live-scores__scroll {
    display: flex;
    gap: 12px;
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
    padding-bottom: 4px;
    scrollbar-width: none;
}
.live-scores__scroll::-webkit-scrollbar { display: none; }
.live-card {
    background: var(--gp-bg-card);
    border-radius: var(--gp-radius);
    box-shadow: var(--gp-shadow);
    min-width: 280px;
    flex-shrink: 0;
    overflow: hidden;
}
.live-card__header {
    background: var(--gp-darker);
    color: #fff;
    padding: 10px 14px;
    display: flex;
    justify-content: space-between;
    align-items: center;
}
.live-card__tour { font-size: 11px; font-weight: 700; text-transform: uppercase; letter-spacing: 0.5px; }
.live-card__status { font-size: 11px; color: var(--gp-green); font-weight: 600; }
.live-card__name { font-size: 14px; font-weight: 700; padding: 10px 14px 4px; }
.live-card__row {
    display: flex;
    justify-content: space-between;
    padding: 5px 14px;
    font-size: 13px;
    border-bottom: 1px solid var(--gp-border);
}
.live-card__row:last-child { border-bottom: none; }
.live-card__pos { width: 24px; color: var(--gp-text-muted); font-weight: 600; }
.live-card__player { flex: 1; }
.live-card__score { font-weight: 700; color: var(--gp-red); min-width: 40px; text-align: right; }
.live-card__footer { padding: 8px 14px; text-align: center; border-top: 1px solid var(--gp-border); }
.live-card__footer a { font-size: 12px; font-weight: 600; }

/* ============================================================
   NEWS GRID
   ============================================================ */
.news-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 16px;
}
@media (max-width: 900px) { .news-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 560px) { .news-grid { grid-template-columns: 1fr; } }

.news-card {
    background: var(--gp-bg-card);
    border-radius: var(--gp-radius);
    box-shadow: var(--gp-shadow);
    overflow: hidden;
    transition: transform var(--gp-transition), box-shadow var(--gp-transition);
    cursor: pointer;
}
.news-card:hover { transform: translateY(-2px); box-shadow: var(--gp-shadow-lg); }
.news-card__image {
    height: 160px;
    background-size: cover;
    background-position: center;
    position: relative;
}
.news-card__badge {
    position: absolute;
    top: 10px;
    left: 10px;
    font-size: 11px;
    font-weight: 700;
    text-transform: uppercase;
    padding: 3px 8px;
    border-radius: 3px;
    background: var(--gp-green);
    color: #fff;
    letter-spacing: 0.3px;
}
.news-card__badge--equipment { background: #1565C0; }
.news-card__badge--reise { background: #EF6C00; }
.news-card__badge--deals { background: var(--gp-gold); color: var(--gp-darker); }
.news-card__badge--training { background: #7B1FA2; }
.news-card__badge--ladies { background: #9c27b0; }
.news-card__badge--panorama { background: #455a64; }
.news-card__badge--amateur { background: #558b2f; }
.news-card__body { padding: 14px; }
.news-card__title {
    font-size: 15px;
    font-weight: 700;
    line-height: 1.35;
    margin-bottom: 6px;
    color: var(--gp-text);
    display: -webkit-box;
    -webkit-line-clamp: 3;
    -webkit-box-orient: vertical;
    overflow: hidden;
}
.news-card__meta { font-size: 12px; color: var(--gp-text-muted); }

/* ============================================================
   TRAINING SECTION
   ============================================================ */
.training-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; }
@media (max-width: 767px) { .training-grid { grid-template-columns: 1fr; } }
.training-card {
    background: var(--gp-bg-card);
    border-radius: var(--gp-radius);
    box-shadow: var(--gp-shadow);
    overflow: hidden;
    cursor: pointer;
    transition: transform var(--gp-transition);
}
.training-card:hover { transform: translateY(-2px); }
.training-card__video {
    height: 200px;
    position: relative;
    display: flex;
    align-items: center;
    justify-content: center;
}
.training-card__play {
    width: 56px; height: 56px;
    background: rgba(0,0,0,0.6);
    border-radius: 50%;
    display: flex; align-items: center; justify-content: center;
    color: #fff; font-size: 24px;
    position: relative; z-index: 2;
    transition: background var(--gp-transition);
}
.training-card:hover .training-card__play { background: var(--gp-green); }
.training-card__overlay {
    position: absolute; inset: 0;
    background: linear-gradient(to top, rgba(0,0,0,0.5) 0%, rgba(0,0,0,0.05) 60%);
}
.training-card__duration {
    position: absolute; bottom: 10px; right: 10px;
    background: rgba(0,0,0,0.7); color: #fff;
    font-size: 11px; font-weight: 600;
    padding: 2px 8px; border-radius: 3px; z-index: 2;
}
.training-card__body { padding: 14px; }
.training-card__tag {
    font-size: 11px; font-weight: 700; text-transform: uppercase;
    color: #7B1FA2; letter-spacing: 0.3px; margin-bottom: 4px;
}
.training-card__title { font-size: 16px; font-weight: 700; line-height: 1.3; margin-bottom: 4px; }
.training-card__coach { font-size: 13px; color: var(--gp-text-muted); }
.training-tips { display: grid; grid-template-columns: repeat(4, 1fr); gap: 12px; margin-top: 16px; }
@media (max-width: 900px) { .training-tips { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 560px) { .training-tips { grid-template-columns: 1fr; } }
.training-tip {
    background: var(--gp-bg-card);
    border-radius: var(--gp-radius);
    box-shadow: var(--gp-shadow);
    padding: 16px; cursor: pointer;
    transition: transform var(--gp-transition);
}
.training-tip:hover { transform: translateY(-2px); }
.training-tip__icon { font-size: 28px; margin-bottom: 8px; }
.training-tip__title { font-size: 14px; font-weight: 700; margin-bottom: 4px; }
.training-tip__desc { font-size: 12px; color: var(--gp-text-muted); line-height: 1.4; }

/* ============================================================
   TOP ARTICLES
   ============================================================ */
.top-articles { counter-reset: rank; }
.top-article {
    display: flex; align-items: center; gap: 16px;
    padding: 12px 0; border-bottom: 1px solid var(--gp-border);
    cursor: pointer; transition: background var(--gp-transition);
}
.top-article:hover { background: var(--gp-green-tint); margin: 0 -8px; padding: 12px 8px; }
.top-article:last-child { border-bottom: none; }
.top-article__rank { font-size: 24px; font-weight: 800; color: var(--gp-green); min-width: 36px; text-align: center; }
.top-article__rank--gold { color: var(--gp-gold); }
.top-article__image { width: 80px; height: 60px; border-radius: var(--gp-radius-sm); flex-shrink: 0; }
.top-article__content { flex: 1; min-width: 0; }
.top-article__title {
    font-size: 14px; font-weight: 600; line-height: 1.3; color: var(--gp-text);
    display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden;
}
.top-article__meta { font-size: 12px; color: var(--gp-text-muted); margin-top: 2px; }

/* ============================================================
   EQUIPMENT CAROUSEL
   ============================================================ */
.equipment-scroll {
    display: flex; gap: 12px; overflow-x: auto;
    -webkit-overflow-scrolling: touch; padding-bottom: 4px; scrollbar-width: none;
}
.equipment-scroll::-webkit-scrollbar { display: none; }
.equip-card {
    background: var(--gp-bg-card); border-radius: var(--gp-radius);
    box-shadow: var(--gp-shadow); min-width: 200px; max-width: 200px;
    flex-shrink: 0; overflow: hidden;
    transition: transform var(--gp-transition); cursor: pointer;
}
.equip-card:hover { transform: translateY(-2px); }
.equip-card__image {
    height: 160px; background: #f0f0f0;
    display: flex; align-items: center; justify-content: center;
    font-size: 48px; color: #ccc;
}
.equip-card__body { padding: 12px; }
.equip-card__brand { font-size: 11px; font-weight: 700; text-transform: uppercase; color: var(--gp-text-muted); letter-spacing: 0.5px; }
.equip-card__name { font-size: 14px; font-weight: 600; margin: 4px 0; color: var(--gp-text); display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden; }
.equip-card__price { font-size: 16px; font-weight: 700; color: var(--gp-green); }
.equip-card__shop { font-size: 11px; color: var(--gp-text-muted); margin-top: 2px; }

/* ============================================================
   LIVETICKER TEASER
   ============================================================ */
.liveticker-teaser {
    background: linear-gradient(135deg, var(--gp-darker), #0d2118);
    border-radius: var(--gp-radius);
    padding: 40px 24px;
    display: flex; align-items: center; gap: 32px;
    color: #fff; overflow: hidden; position: relative;
}
@media (max-width: 767px) {
    .liveticker-teaser { flex-direction: column; text-align: center; padding: 32px 20px; }
}
.liveticker-teaser__visual {
    flex-shrink: 0; width: 200px; height: 140px;
    border-radius: var(--gp-radius);
    background: rgba(255,255,255,0.05);
    border: 1px solid rgba(255,255,255,0.1);
    display: flex; flex-direction: column; overflow: hidden;
}
.liveticker-teaser__mockup-header {
    background: var(--gp-green); padding: 6px 10px;
    font-size: 10px; font-weight: 700; text-transform: uppercase;
    display: flex; justify-content: space-between;
}
.liveticker-teaser__mockup-dot {
    width: 6px; height: 6px; background: var(--gp-red);
    border-radius: 50%; animation: pulse-badge 1.5s infinite;
}
.liveticker-teaser__mockup-line {
    padding: 4px 10px; font-size: 11px; color: rgba(255,255,255,0.7);
    border-bottom: 1px solid rgba(255,255,255,0.05);
    display: flex; justify-content: space-between;
}
.liveticker-teaser__mockup-line span:last-child { color: var(--gp-green); font-weight: 600; }
.liveticker-teaser__content { flex: 1; }
.liveticker-teaser__title { font-size: 22px; font-weight: 700; margin-bottom: 8px; }
.liveticker-teaser__desc { font-size: 15px; color: rgba(255,255,255,0.7); margin-bottom: 16px; line-height: 1.5; }
.liveticker-teaser__features { display: flex; gap: 20px; flex-wrap: wrap; margin-bottom: 20px; }
.liveticker-teaser__feature { font-size: 13px; color: rgba(255,255,255,0.8); display: flex; align-items: center; gap: 6px; }
.liveticker-teaser__feature-dot { width: 8px; height: 8px; border-radius: 50%; background: var(--gp-green); }

/* ============================================================
   GOLFCLUBS
   ============================================================ */
.clubs-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 16px; }
@media (max-width: 900px) { .clubs-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 560px) { .clubs-grid { grid-template-columns: 1fr; } }
.club-card {
    background: var(--gp-bg-card); border-radius: var(--gp-radius);
    box-shadow: var(--gp-shadow); overflow: hidden;
    transition: transform var(--gp-transition); cursor: pointer;
}
.club-card:hover { transform: translateY(-2px); }
.club-card__image { height: 130px; background-size: cover; background-position: center; }
.club-card__body { padding: 12px; }
.club-card__name { font-size: 14px; font-weight: 700; color: var(--gp-text); margin-bottom: 2px; }
.club-card__location { font-size: 12px; color: var(--gp-text-muted); margin-bottom: 6px; }
.club-card__rating { display: flex; align-items: center; gap: 4px; }
.club-card__stars { color: var(--gp-gold); font-size: 13px; letter-spacing: 1px; }
.club-card__score { font-size: 12px; font-weight: 700; color: var(--gp-text); }

/* ============================================================
   GOLFREISEN
   ============================================================ */
.travel-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 12px; }
@media (max-width: 900px) { .travel-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 560px) { .travel-grid { grid-template-columns: 1fr; } }
.travel-card {
    position: relative; height: 200px; border-radius: var(--gp-radius);
    overflow: hidden; cursor: pointer; transition: transform var(--gp-transition);
}
.travel-card:hover { transform: translateY(-2px); }
.travel-card__bg {
    position: absolute; inset: 0; background-size: cover; background-position: center;
    transition: transform 0.4s ease;
}
.travel-card:hover .travel-card__bg { transform: scale(1.05); }
.travel-card__overlay { position: absolute; inset: 0; background: linear-gradient(to top, rgba(0,0,0,0.65) 0%, rgba(0,0,0,0.1) 60%); }
.travel-card__content { position: absolute; bottom: 14px; left: 14px; right: 14px; color: #fff; z-index: 1; }
.travel-card__title { font-size: 17px; font-weight: 700; margin-bottom: 2px; }
.travel-card__price { font-size: 13px; color: rgba(255,255,255,0.85); }

/* ============================================================
   GOLFHOTELS
   ============================================================ */
.hotels-scroll {
    display: flex; gap: 16px; overflow-x: auto;
    -webkit-overflow-scrolling: touch; padding-bottom: 4px; scrollbar-width: none;
}
.hotels-scroll::-webkit-scrollbar { display: none; }
.hotel-card {
    background: var(--gp-bg-card); border-radius: var(--gp-radius);
    box-shadow: var(--gp-shadow); min-width: 260px; max-width: 260px;
    flex-shrink: 0; overflow: hidden; cursor: pointer;
    transition: transform var(--gp-transition);
}
.hotel-card:hover { transform: translateY(-2px); }
.hotel-card__image { height: 150px; background-size: cover; background-position: center; position: relative; }
.hotel-card__stars-badge {
    position: absolute; top: 10px; right: 10px;
    background: rgba(0,0,0,0.6); color: var(--gp-gold);
    font-size: 12px; padding: 3px 8px; border-radius: 3px; letter-spacing: 1px;
}
.hotel-card__body { padding: 14px; }
.hotel-card__name { font-size: 15px; font-weight: 700; margin-bottom: 2px; }
.hotel-card__location { font-size: 12px; color: var(--gp-text-muted); margin-bottom: 8px; }
.hotel-card__footer { display: flex; justify-content: space-between; align-items: baseline; }
.hotel-card__price { font-size: 16px; font-weight: 700; color: var(--gp-green); }
.hotel-card__price span { font-size: 12px; font-weight: 400; color: var(--gp-text-muted); }
.hotel-card__rating { font-size: 13px; color: var(--gp-gold); font-weight: 600; }

/* ============================================================
   TOPIC ROWS
   ============================================================ */
.topic-row {
    display: flex; gap: 16px; overflow-x: auto;
    -webkit-overflow-scrolling: touch; padding-bottom: 4px; scrollbar-width: none;
}
.topic-row::-webkit-scrollbar { display: none; }
.topic-card {
    background: var(--gp-bg-card); border-radius: var(--gp-radius);
    box-shadow: var(--gp-shadow); min-width: 260px; max-width: 260px;
    flex-shrink: 0; overflow: hidden; cursor: pointer;
    transition: transform var(--gp-transition); display: flex;
}
.topic-card:hover { transform: translateY(-2px); }
.topic-card__image { width: 100px; min-height: 100px; background-size: cover; background-position: center; flex-shrink: 0; }
.topic-card__body { padding: 12px; flex: 1; min-width: 0; }
.topic-card__title {
    font-size: 14px; font-weight: 700; line-height: 1.3; margin-bottom: 4px;
    display: -webkit-box; -webkit-line-clamp: 3; -webkit-box-orient: vertical; overflow: hidden;
}
.topic-card__meta { font-size: 12px; color: var(--gp-text-muted); }

/* ============================================================
   COMMUNITY & BLOGS
   ============================================================ */
.community-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; }
@media (max-width: 767px) { .community-grid { grid-template-columns: 1fr; } }
.community-box {
    background: var(--gp-bg-card); border-radius: var(--gp-radius);
    box-shadow: var(--gp-shadow); padding: 20px;
}
.community-box__title { font-size: 16px; font-weight: 700; margin-bottom: 12px; display: flex; align-items: center; gap: 8px; }
.blog-post { display: flex; gap: 12px; padding: 10px 0; border-bottom: 1px solid var(--gp-border); cursor: pointer; }
.blog-post:last-child { border-bottom: none; }
.blog-post__avatar {
    width: 36px; height: 36px; border-radius: 50%; flex-shrink: 0;
    display: flex; align-items: center; justify-content: center;
    color: #fff; font-weight: 700; font-size: 14px;
}
.blog-post__content { flex: 1; min-width: 0; }
.blog-post__author { font-size: 12px; font-weight: 600; color: var(--gp-green); }
.blog-post__title {
    font-size: 14px; font-weight: 600; line-height: 1.3;
    display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden;
}
.blog-post__meta { font-size: 11px; color: var(--gp-text-muted); margin-top: 2px; }
.community-activity__item {
    padding: 8px 0; border-bottom: 1px solid var(--gp-border);
    font-size: 13px; color: var(--gp-text-secondary);
    display: flex; align-items: center; gap: 8px;
}
.community-activity__item:last-child { border-bottom: none; }
.community-activity__dot { width: 6px; height: 6px; border-radius: 50%; background: var(--gp-green); flex-shrink: 0; }

/* ============================================================
   GAMIFICATION TEASER
   ============================================================ */
.gamification-teaser {
    background: linear-gradient(135deg, #1a3a2a, #0d2118);
    border-radius: var(--gp-radius); padding: 32px 24px; color: #fff; text-align: center;
}
.gamification-teaser__badges { display: flex; justify-content: center; gap: 24px; margin: 20px 0; flex-wrap: wrap; }
.gamification-badge { display: flex; flex-direction: column; align-items: center; gap: 6px; }
.gamification-badge__icon {
    width: 56px; height: 56px; border-radius: 50%;
    background: rgba(255,255,255,0.1); border: 2px solid rgba(255,255,255,0.2);
    display: flex; align-items: center; justify-content: center;
    font-size: 24px; transition: var(--gp-transition);
}
.gamification-badge--locked .gamification-badge__icon { opacity: 0.4; filter: grayscale(100%); }
.gamification-badge__label { font-size: 11px; color: rgba(255,255,255,0.7); }
.gamification-teaser__desc { font-size: 15px; color: rgba(255,255,255,0.7); margin-bottom: 20px; line-height: 1.5; }

/* ============================================================
   APP DOWNLOAD CTA
   ============================================================ */
.app-cta {
    background: var(--gp-bg-card); border-radius: var(--gp-radius);
    box-shadow: var(--gp-shadow); padding: 24px;
    display: flex; align-items: center; gap: 24px;
}
@media (max-width: 767px) { .app-cta { flex-direction: column; text-align: center; } }
.app-cta__phone {
    width: 80px; height: 140px; border-radius: 16px;
    background: var(--gp-darker); border: 2px solid #444;
    display: flex; align-items: center; justify-content: center;
    flex-shrink: 0; position: relative; overflow: hidden;
}
.app-cta__phone-screen {
    width: 60px; height: 110px; border-radius: 8px;
    background: linear-gradient(180deg, var(--gp-green), #1a5a45);
    display: flex; align-items: center; justify-content: center;
    color: #fff; font-weight: 800; font-size: 14px;
}
.app-cta__content { flex: 1; }
.app-cta__title { font-size: 18px; font-weight: 700; margin-bottom: 4px; }
.app-cta__desc { font-size: 14px; color: var(--gp-text-muted); margin-bottom: 16px; }
.app-cta__badges { display: flex; gap: 12px; }
@media (max-width: 767px) { .app-cta__badges { justify-content: center; } }
.app-badge {
    display: inline-flex; align-items: center; gap: 6px;
    background: var(--gp-darker); color: #fff;
    padding: 8px 16px; border-radius: var(--gp-radius-sm);
    font-size: 12px; font-weight: 600; cursor: pointer;
    transition: background var(--gp-transition);
}
.app-badge:hover { background: #333; text-decoration: none; }
.app-badge__icon { font-size: 18px; }

/* ============================================================
   CTA BANNER
   ============================================================ */
.cta-banner {
    background: linear-gradient(135deg, var(--gp-green), var(--gp-green-dark));
    border-radius: var(--gp-radius); padding: 28px 24px; text-align: center; color: #fff;
}
.cta-banner__title { font-size: 20px; font-weight: 700; margin-bottom: 8px; }
.cta-banner__desc { font-size: 15px; color: rgba(255,255,255,0.85); margin-bottom: 16px; }

/* ============================================================
   COMMUNITY STATS
   ============================================================ */
.community-stats { display: flex; justify-content: center; gap: 40px; flex-wrap: wrap; margin-bottom: 20px; }
.community-stats__item { text-align: center; }
.community-stats__number { font-size: 28px; font-weight: 800; color: var(--gp-green); }
.community-stats__label { font-size: 13px; color: var(--gp-text-muted); }

/* ============================================================
   NEWSLETTER CTA
   ============================================================ */
.newsletter-cta {
    background: var(--gp-darker); color: #fff;
    border-radius: var(--gp-radius); padding: 40px 20px; text-align: center;
}
.newsletter-cta__title { font-size: 22px; font-weight: 700; margin-bottom: 6px; }
.newsletter-cta__subtitle { font-size: 15px; color: rgba(255,255,255,0.7); margin-bottom: 20px; }
.newsletter-cta__form { display: flex; gap: 8px; max-width: 440px; margin: 0 auto; }
.newsletter-cta__input {
    flex: 1; padding: 12px 16px; border: none;
    border-radius: var(--gp-radius-sm); font-size: 15px;
    font-family: var(--gp-font); outline: none;
}
.newsletter-cta__input::placeholder { color: #aaa; }
@media (max-width: 480px) { .newsletter-cta__form { flex-direction: column; } }

/* ============================================================
   PREMIUM TEASER
   ============================================================ */
.premium-teaser {
    background: linear-gradient(135deg, #1a3a2a, #0d2118);
    color: #fff; border-radius: var(--gp-radius); padding: 32px 24px;
    display: flex; align-items: center; gap: 32px;
}
@media (max-width: 767px) { .premium-teaser { flex-direction: column; text-align: center; } }
.premium-teaser__icon { font-size: 48px; flex-shrink: 0; }
.premium-teaser__content { flex: 1; }
.premium-teaser__title { font-size: 20px; font-weight: 700; margin-bottom: 8px; }
.premium-teaser__title span { color: var(--gp-gold); }
.premium-teaser__benefits { list-style: none; margin-bottom: 16px; }
.premium-teaser__benefits li { font-size: 14px; color: rgba(255,255,255,0.8); padding: 3px 0; }
.premium-teaser__benefits li::before { content: "\2713 "; color: var(--gp-green); font-weight: 700; margin-right: 6px; }

/* ============================================================
   MY CLUB (logged-in only)
   ============================================================ */
.my-club {
    background: var(--gp-bg-card); border-radius: var(--gp-radius);
    box-shadow: var(--gp-shadow); padding: 20px;
    display: flex; gap: 20px; align-items: flex-start;
}
@media (max-width: 767px) { .my-club { flex-direction: column; } }
.my-club__photo {
    width: 200px; height: 140px; border-radius: var(--gp-radius-sm);
    background-size: cover; background-position: center; flex-shrink: 0;
}
@media (max-width: 767px) { .my-club__photo { width: 100%; height: 160px; } }
.my-club__info { flex: 1; }
.my-club__name { font-size: 18px; font-weight: 700; margin-bottom: 4px; }
.my-club__location { font-size: 13px; color: var(--gp-text-muted); margin-bottom: 12px; }
.my-club__activity { border-top: 1px solid var(--gp-border); padding-top: 10px; }
.my-club__activity-item {
    font-size: 13px; color: var(--gp-text-secondary); padding: 4px 0;
    display: flex; align-items: center; gap: 8px;
}
.my-club__activity-dot { width: 6px; height: 6px; border-radius: 50%; background: var(--gp-green); flex-shrink: 0; }

/* ============================================================
   MY EQUIPMENT (logged-in only)
   ============================================================ */
.my-equip-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(240px, 1fr)); gap: 12px; }
.my-equip-card {
    background: var(--gp-bg-card); border-radius: var(--gp-radius);
    box-shadow: var(--gp-shadow); padding: 14px;
    display: flex; gap: 12px; align-items: center;
}
.my-equip-card__icon {
    width: 56px; height: 56px; border-radius: var(--gp-radius-sm);
    background: #f0f0f0; display: flex; align-items: center; justify-content: center;
    font-size: 24px; color: #bbb; flex-shrink: 0;
}
.my-equip-card__info { flex: 1; min-width: 0; }
.my-equip-card__category { font-size: 11px; color: var(--gp-text-muted); text-transform: uppercase; font-weight: 700; letter-spacing: 0.3px; }
.my-equip-card__name { font-size: 14px; font-weight: 600; color: var(--gp-text); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.my-equip-card__hint { font-size: 12px; color: var(--gp-green); font-weight: 600; }

/* ============================================================
   FEED (logged-in endless scroll)
   ============================================================ */
.feed-header { display: flex; align-items: center; gap: 12px; margin-bottom: 16px; }
.feed-header__avatar {
    width: 40px; height: 40px; border-radius: 50%; background: var(--gp-green);
    color: #fff; display: flex; align-items: center; justify-content: center;
    font-weight: 700; font-size: 16px;
}
.feed-header__text { font-size: 18px; font-weight: 600; }
.feed-tags { display: flex; gap: 8px; flex-wrap: wrap; margin-bottom: 16px; }
.feed-tag {
    padding: 6px 14px; border-radius: 20px; font-size: 13px; font-weight: 600;
    border: 1.5px solid var(--gp-border); color: var(--gp-text-secondary);
    background: #fff; cursor: pointer; transition: var(--gp-transition);
}
.feed-tag:hover, .feed-tag--active {
    border-color: var(--gp-green); color: var(--gp-green); background: var(--gp-green-tint);
}
.feed-item {
    background: var(--gp-bg-card); border-radius: var(--gp-radius);
    box-shadow: var(--gp-shadow); margin-bottom: 16px; overflow: hidden;
}
.feed-item__image {
    height: 200px; background-size: cover; background-position: center; position: relative;
}
.feed-item__badge {
    position: absolute; top: 10px; left: 10px;
    font-size: 11px; font-weight: 700; text-transform: uppercase;
    padding: 3px 8px; border-radius: 3px; color: #fff; letter-spacing: 0.3px;
}
.feed-item__body { padding: 16px; }
.feed-item__title { font-size: 17px; font-weight: 700; line-height: 1.3; margin-bottom: 6px; }
.feed-item__excerpt { font-size: 14px; color: var(--gp-text-secondary); line-height: 1.5; margin-bottom: 8px; }
.feed-item__meta { font-size: 12px; color: var(--gp-text-muted); }
.feed-item--compact { display: flex; }
.feed-item--compact .feed-item__image { width: 180px; height: auto; min-height: 120px; flex-shrink: 0; }
.feed-item--compact .feed-item__body { flex: 1; }
@media (max-width: 560px) {
    .feed-item--compact { flex-direction: column; }
    .feed-item--compact .feed-item__image { width: 100%; height: 160px; }
}
.feed-divider {
    text-align: center; padding: 8px 0; font-size: 12px;
    color: var(--gp-text-muted); text-transform: uppercase; letter-spacing: 1px;
}

/* ============================================================
   BUTTONS
   ============================================================ */
.btn {
    display: inline-flex; align-items: center; justify-content: center;
    padding: 12px 24px; border-radius: var(--gp-radius-sm);
    font-size: 14px; font-weight: 700; font-family: var(--gp-font);
    cursor: pointer; border: none;
    transition: background var(--gp-transition), transform var(--gp-transition);
    text-decoration: none;
}
.btn:hover { transform: translateY(-1px); text-decoration: none; }
.btn--green { background: var(--gp-green); color: #fff; }
.btn--green:hover { background: var(--gp-green-dark); }
.btn--white { background: #fff; color: var(--gp-green); }
.btn--white:hover { background: #f0f0f0; }
.btn--outline { background: transparent; color: #fff; border: 2px solid rgba(255,255,255,0.4); }
.btn--outline:hover { border-color: #fff; background: rgba(255,255,255,0.1); }
.btn--gold { background: var(--gp-gold); color: var(--gp-darker); }
.btn--gold:hover { background: #ffc107; }
.btn--sm { padding: 8px 16px; font-size: 13px; }

/* ============================================================
   FOOTER
   ============================================================ */
.site-footer {
    background: var(--gp-darker); color: rgba(255,255,255,0.7);
    padding: 40px 0 20px; margin-top: 32px; font-size: 13px;
}
.footer-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 32px; margin-bottom: 32px; }
@media (max-width: 767px) { .footer-grid { grid-template-columns: repeat(2, 1fr); gap: 24px; } }
.footer-col__title { font-size: 14px; font-weight: 700; color: #fff; margin-bottom: 12px; }
.footer-col ul { list-style: none; }
.footer-col li { padding: 3px 0; }
.footer-col a { color: rgba(255,255,255,0.6); }
.footer-col a:hover { color: #fff; text-decoration: none; }
.footer-bottom {
    border-top: 1px solid rgba(255,255,255,0.1); padding-top: 20px;
    display: flex; justify-content: space-between; align-items: center;
    flex-wrap: wrap; gap: 12px;
}
.footer-social { display: flex; gap: 16px; }
.footer-social a {
    color: rgba(255,255,255,0.5); font-size: 18px;
    width: 36px; height: 36px;
    display: flex; align-items: center; justify-content: center;
    border-radius: 50%; background: rgba(255,255,255,0.08);
    transition: background var(--gp-transition);
}
.footer-social a:hover { background: var(--gp-green); color: #fff; text-decoration: none; }

/* ============================================================
   PLACEHOLDER IMAGES
   ============================================================ */
.placeholder-img { background: linear-gradient(135deg, #2B7860 0%, #1a5a45 50%, #04AE79 100%); }
.placeholder-img--1 { background: linear-gradient(135deg, #1a5a45, #2B7860); }
.placeholder-img--2 { background: linear-gradient(135deg, #0d3d2e, #1a5a45); }
.placeholder-img--3 { background: linear-gradient(135deg, #04AE79, #039768); }
.placeholder-img--4 { background: linear-gradient(135deg, #2c5f4a, #1a3a2a); }
.placeholder-img--5 { background: linear-gradient(135deg, #3a7d54, #04AE79); }
.placeholder-img--club { background: linear-gradient(135deg, #3a7d54, #2B5f40); }
.placeholder-img--travel-1 { background: linear-gradient(135deg, #e67e22, #d35400); }
.placeholder-img--travel-2 { background: linear-gradient(135deg, #3498db, #2980b9); }
.placeholder-img--travel-3 { background: linear-gradient(135deg, #27ae60, #1e8449); }
.placeholder-img--travel-4 { background: linear-gradient(135deg, #e74c3c, #c0392b); }
.placeholder-img--hotel-1 { background: linear-gradient(135deg, #2E86AB, #1B6A8D); }
.placeholder-img--hotel-2 { background: linear-gradient(135deg, #A23B72, #C64B8C); }
.placeholder-img--hotel-3 { background: linear-gradient(135deg, #F18F01, #C47200); }
.placeholder-img--hotel-4 { background: linear-gradient(135deg, #4A6741, #6B8E5A); }
.placeholder-img--training-1 { background: linear-gradient(135deg, #7B1FA2, #9C27B0); }
.placeholder-img--training-2 { background: linear-gradient(135deg, #512DA8, #7C4DFF); }
.placeholder-img--ladies { background: linear-gradient(135deg, #9c27b0, #ce93d8); }
.placeholder-img--panorama { background: linear-gradient(135deg, #455a64, #78909c); }
.placeholder-img--amateur { background: linear-gradient(135deg, #558b2f, #8bc34a); }
/* Concierge reco card images */
.placeholder-img--mauritius { background: linear-gradient(135deg, #0077b6, #00b4d8); }
.placeholder-img--algarve { background: linear-gradient(135deg, #e76f51, #f4a261); }
.placeholder-img--taylormade { background: linear-gradient(135deg, #1565C0, #42a5f5); }
.placeholder-img--callaway { background: linear-gradient(135deg, #1a3a6c, #4a90d9); }
.placeholder-img--eichenried { background: linear-gradient(135deg, #2e7d32, #66bb6a); }
.placeholder-img--olching { background: linear-gradient(135deg, #388e3c, #81c784); }

/* ============================================================
   FREEMIUM GATE MODALS
   ============================================================ */
.gate-overlay {
    display: none;
    position: fixed;
    inset: 0;
    background: rgba(0,0,0,0.55);
    backdrop-filter: blur(6px);
    -webkit-backdrop-filter: blur(6px);
    z-index: 3000;
    align-items: center;
    justify-content: center;
    padding: 20px;
    opacity: 0;
    transition: opacity 0.3s ease;
}
.gate-overlay.visible { display: flex; }
.gate-overlay.fade-in { opacity: 1; }
.gate-modal {
    background: #fff;
    border-radius: 16px;
    width: 100%;
    max-width: 440px;
    padding: 36px 28px 28px;
    text-align: center;
    box-shadow: 0 20px 60px rgba(0,0,0,0.25);
    transform: translateY(20px);
    transition: transform 0.3s ease;
    position: relative;
}
.gate-overlay.fade-in .gate-modal { transform: translateY(0); }
.gate-modal__close {
    position: absolute;
    top: 12px;
    right: 16px;
    background: none;
    border: none;
    font-size: 22px;
    color: var(--gp-text-muted);
    cursor: pointer;
    transition: color var(--gp-transition);
}
.gate-modal__close:hover { color: var(--gp-text); }
.gate-modal__icon { font-size: 40px; margin-bottom: 12px; }
.gate-modal__title {
    font-size: 22px;
    font-weight: 700;
    color: var(--gp-text);
    margin-bottom: 8px;
    line-height: 1.3;
}
.gate-modal__text {
    font-size: 15px;
    color: var(--gp-text-secondary);
    margin-bottom: 24px;
    line-height: 1.6;
}
.gate-modal__buttons { display: flex; flex-direction: column; gap: 10px; margin-bottom: 16px; }
.gate-modal__btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: 14px 24px;
    border-radius: var(--gp-radius-sm);
    font-size: 15px;
    font-weight: 700;
    font-family: var(--gp-font);
    cursor: pointer;
    border: none;
    transition: all var(--gp-transition);
    text-decoration: none;
}
.gate-modal__btn--primary { background: var(--gp-green); color: #fff; }
.gate-modal__btn--primary:hover { background: var(--gp-green-dark); text-decoration: none; }
.gate-modal__btn--outline {
    background: #fff;
    color: var(--gp-text);
    border: 2px solid var(--gp-border);
}
.gate-modal__btn--outline:hover { border-color: var(--gp-green); color: var(--gp-green); text-decoration: none; }
.gate-modal__btn--gold { background: var(--gp-gold); color: var(--gp-darker); }
.gate-modal__btn--gold:hover { background: #ffc107; text-decoration: none; }
.gate-modal__hint {
    font-size: 12px;
    color: var(--gp-text-muted);
    line-height: 1.5;
}
.gate-modal__counter {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    background: #fff3e0;
    color: #e65100;
    font-size: 14px;
    font-weight: 700;
    padding: 8px 16px;
    border-radius: 20px;
    margin-bottom: 16px;
}
.gate-modal__hint a { color: var(--gp-green); }

/* Concierge query counter (under input) */
.concierge__counter {
    text-align: center;
    margin-top: 8px;
    font-size: 12px;
    color: rgba(255,255,255,0.45);
    position: relative;
    z-index: 1;
}
.concierge__counter-text { display: inline-flex; align-items: center; gap: 6px; }
.concierge__counter-badge {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    background: rgba(255,215,0,0.15);
    border: 1px solid rgba(255,215,0,0.3);
    color: var(--gp-gold);
    font-size: 11px;
    font-weight: 700;
    padding: 3px 10px;
    border-radius: 12px;
    letter-spacing: 0.3px;
}

/* View Toggle: 3-button version */
.view-toggle--three { border-radius: 24px; }

/* ============================================================
   FREEMIUM: Locked CTA Buttons (Anonymous)
   ============================================================ */
.chat-reco-card__btn--locked {
    opacity: 0.4;
    pointer-events: none;
    position: relative;
    cursor: default;
}
.chat-reco-card__btn--locked .lock-icon {
    margin-left: 4px;
    font-size: 11px;
}
/* Lock overlay tooltip on hover */
.chat-reco-card__actions--locked {
    position: relative;
}
.chat-reco-card__actions--locked::after {
    content: 'Kostenlos anmelden um fortzufahren';
    position: absolute;
    bottom: calc(100% + 6px);
    left: 50%;
    transform: translateX(-50%);
    background: rgba(0,0,0,0.85);
    color: #fff;
    font-size: 11px;
    font-weight: 600;
    padding: 6px 12px;
    border-radius: 6px;
    white-space: nowrap;
    opacity: 0;
    pointer-events: none;
    transition: opacity 0.2s ease;
    z-index: 10;
}
.chat-reco-card__actions--locked:hover::after {
    opacity: 1;
}

/* Premium Extra Buttons */
.chat-reco-card__btn--premium {
    background: var(--gp-gold);
    color: var(--gp-darker);
    font-weight: 700;
}
.chat-reco-card__btn--premium:hover {
    background: #ffc107;
}

/* Info Cards (Rules tab) */
.chat-info-card {
    background: rgba(255,255,255,0.06);
    border: 1px solid rgba(255,255,255,0.12);
    border-radius: 10px;
    padding: 14px 16px;
    margin-bottom: 8px;
}
.chat-info-card__title {
    font-size: 14px;
    font-weight: 700;
    color: #fff;
    margin-bottom: 4px;
    display: flex;
    align-items: center;
    gap: 6px;
}
.chat-info-card__text {
    font-size: 13px;
    color: rgba(255,255,255,0.75);
    line-height: 1.5;
}
.chat-info-card__source {
    font-size: 11px;
    color: rgba(255,255,255,0.4);
    margin-top: 6px;
}

/* Stats Card (Players tab) */
.chat-stats-card {
    background: rgba(255,255,255,0.06);
    border: 1px solid rgba(255,255,255,0.12);
    border-radius: 10px;
    padding: 16px;
    margin-bottom: 8px;
}
.chat-stats-card__title {
    font-size: 14px;
    font-weight: 700;
    color: #fff;
    margin-bottom: 10px;
}
.chat-stats-row {
    display: flex;
    justify-content: space-between;
    padding: 5px 0;
    font-size: 13px;
    color: rgba(255,255,255,0.8);
    border-bottom: 1px solid rgba(255,255,255,0.06);
}
.chat-stats-row:last-child { border-bottom: none; }
.chat-stats-row__label { color: rgba(255,255,255,0.5); }
.chat-stats-row__value { font-weight: 600; color: #fff; }
.chat-stats-row__value--gold { color: var(--gp-gold); }
.chat-stats-summary {
    display: flex;
    gap: 16px;
    flex-wrap: wrap;
    margin-top: 10px;
    padding-top: 10px;
    border-top: 1px solid rgba(255,255,255,0.1);
}
.chat-stats-summary__item {
    font-size: 12px;
    color: rgba(255,255,255,0.6);
}
.chat-stats-summary__item strong {
    color: #fff;
    font-size: 14px;
}

/* Concierge Tabs responsive: scroll on small screens */
@media (max-width: 600px) {
    .concierge__tabs {
        justify-content: flex-start;
        overflow-x: auto;
        -webkit-overflow-scrolling: touch;
        scrollbar-width: none;
        padding-bottom: 4px;
    }
    .concierge__tabs::-webkit-scrollbar { display: none; }
    .concierge__tab { white-space: nowrap; padding: 8px 16px; font-size: 13px; }
}

/* Prototype simulation controls */
.proto-controls {
    position: fixed;
    bottom: 16px;
    left: 16px;
    z-index: 4000;
    background: #fff;
    border-radius: 12px;
    box-shadow: var(--gp-shadow-lg);
    border: 2px solid var(--gp-border);
    padding: 12px 16px;
    font-size: 13px;
    max-width: 260px;
}
.proto-controls__title {
    font-weight: 700;
    font-size: 11px;
    text-transform: uppercase;
    letter-spacing: 0.5px;
    color: var(--gp-text-muted);
    margin-bottom: 8px;
}
.proto-controls__row {
    display: flex;
    align-items: center;
    gap: 8px;
    margin-bottom: 6px;
}
.proto-controls__row:last-child { margin-bottom: 0; }
.proto-controls__btn {
    padding: 5px 12px;
    border-radius: 6px;
    font-size: 12px;
    font-weight: 600;
    border: 1.5px solid var(--gp-border);
    background: #fff;
    cursor: pointer;
    font-family: var(--gp-font);
    transition: all var(--gp-transition);
}
.proto-controls__btn:hover { border-color: var(--gp-green); color: var(--gp-green); }
.proto-controls__btn.active { background: var(--gp-green); color: #fff; border-color: var(--gp-green); }

/* ============================================================
   EDITION SWITCHER (Header Dropdown + Footer)
   ============================================================ */

/* Header: Compact Globe Dropdown */
.edition-dropdown { position: relative; }
.edition-dropdown__toggle {
    display: flex;
    align-items: center;
    gap: 4px;
    background: var(--gp-green-tint);
    border: 1.5px solid var(--gp-green);
    border-radius: 20px;
    padding: 6px 12px;
    font-size: 13px;
    font-weight: 600;
    cursor: pointer;
    font-family: var(--gp-font);
    color: var(--gp-green);
    transition: all var(--gp-transition);
}
.edition-dropdown__toggle:hover { background: var(--gp-green); color: #fff; }
.edition-dropdown__globe { font-size: 14px; }
.edition-dropdown__code { text-transform: uppercase; letter-spacing: 0.5px; }
.edition-dropdown__arrow { font-size: 8px; transition: transform 0.2s; }
.edition-dropdown.open .edition-dropdown__arrow { transform: rotate(180deg); }

.edition-dropdown__menu {
    display: none;
    position: absolute;
    top: calc(100% + 6px);
    right: 0;
    background: #fff;
    border: 1px solid var(--gp-border);
    border-radius: var(--gp-radius);
    box-shadow: var(--gp-shadow-lg);
    min-width: 180px;
    z-index: 1000;
    overflow: hidden;
}
.edition-dropdown.open .edition-dropdown__menu { display: block; }

.edition-dropdown__item {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 10px 14px;
    font-size: 13px;
    color: var(--gp-text);
    text-decoration: none;
    transition: background var(--gp-transition);
    cursor: pointer;
}
.edition-dropdown__item:hover { background: var(--gp-green-tint); text-decoration: none; }
.edition-dropdown__item--active {
    background: var(--gp-green-tint);
    font-weight: 600;
    color: var(--gp-green);
}
.edition-dropdown__flag { font-size: 18px; flex-shrink: 0; }
.edition-dropdown__label { flex: 1; }
.edition-dropdown__check { color: var(--gp-green); font-size: 14px; font-weight: 700; }

/* Footer: Full edition list */
.edition-switcher-footer {
    padding: 20px 0;
    border-top: 1px solid rgba(255,255,255,0.1);
}
.edition-switcher-footer__label {
    font-size: 12px;
    font-weight: 700;
    color: rgba(255,255,255,0.5);
    text-transform: uppercase;
    letter-spacing: 1px;
    margin-bottom: 10px;
}
.edition-switcher-footer__list {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
}
.edition-switcher-footer__item {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 6px 12px;
    border-radius: 6px;
    font-size: 13px;
    color: rgba(255,255,255,0.7);
    text-decoration: none;
    background: rgba(255,255,255,0.05);
    transition: all var(--gp-transition);
}
.edition-switcher-footer__item:hover { background: rgba(255,255,255,0.1); color: #fff; text-decoration: none; }
.edition-switcher-footer__item--active {
    background: var(--gp-green);
    color: #fff;
    font-weight: 600;
}
.edition-switcher-footer__flag { font-size: 16px; }

@media (max-width: 767px) {
    .edition-dropdown__code { display: none; }
    .edition-dropdown__toggle { padding: 5px 8px; }
}

/* ============================================================
   DESTINATIONS
   ============================================================ */
.destinations-scroll {
    display: flex; gap: 16px; overflow-x: auto;
    -webkit-overflow-scrolling: touch; padding-bottom: 4px; scrollbar-width: none;
}
.destinations-scroll::-webkit-scrollbar { display: none; }
.destination-card {
    min-width: 220px; max-width: 220px; min-height: 160px;
    border-radius: 12px; flex-shrink: 0; overflow: hidden;
    position: relative; cursor: pointer;
    transition: transform var(--gp-transition);
}
.destination-card:hover { transform: translateY(-2px); }
.destination-card__bg {
    position: absolute; top: 0; left: 0; right: 0; bottom: 0;
    background: linear-gradient(135deg, #0a6e3a 0%, #04ae79 60%, #06c98a 100%);
}
.destination-card:nth-child(2n) .destination-card__bg {
    background: linear-gradient(135deg, #04ae79 0%, #0a6e3a 60%, #064d2e 100%);
}
.destination-card:nth-child(3n) .destination-card__bg {
    background: linear-gradient(135deg, #064d2e 0%, #06c98a 60%, #0a6e3a 100%);
}
.destination-card:nth-child(4n) .destination-card__bg {
    background: linear-gradient(135deg, #06c98a 0%, #064d2e 60%, #04ae79 100%);
}
.destination-card:nth-child(5n) .destination-card__bg {
    background: linear-gradient(135deg, #0a6e3a 0%, #06c98a 40%, #064d2e 100%);
}
.destination-card__content {
    position: relative; z-index: 1; padding: 20px 16px;
    display: flex; flex-direction: column; justify-content: flex-end;
    min-height: 160px; color: #fff;
}
.destination-card__name {
    font-size: 20px; font-weight: 700; line-height: 1.2; margin-bottom: 4px;
}
.destination-card__region {
    font-size: 13px; opacity: 0.85;
}

/* ============================================================
   HERO PLAYER BADGES
   ============================================================ */
.live-card__hero-flag {
    font-size: 12px;
    margin-left: 4px;
    vertical-align: middle;
}
</style>
