/* =========================================== TABOO VACATION - Original Brand Theme Privacy is the Ultimate Luxury =========================================== *//* CSS Variables - Taboo Vacation Brand Palette */:root{/* Base Colors */ --color-black:#0A0A0A;--color-charcoal:#121212;--color-charcoal-light:#1a1a1a;--color-charcoal-lighter:#252525;/* Brand Accent Colors - From Logo */ --color-turquoise:#3DDAD7;/* Primary - Teal from logo */ --color-turquoise-light:#6BE5E3;--color-turquoise-dark:#2BB5B2;--color-pink:#EA008A;/* Secondary - Pink from logo */ --color-pink-light:#FF4DAF;--color-pink-dark:#BB006E;/* Alias for existing code using --color-gold */ --color-gold:var(--color-turquoise);--color-gold-light:var(--color-turquoise-light);--color-gold-dark:var(--color-turquoise-dark);--color-champagne:var(--color-pink);--color-burgundy:var(--color-pink-dark);/* Text Colors */ --color-text-primary:#E0E0E0;--color-text-secondary:#B0B0B0;--color-text-muted:#808080;/* Typography */ --font-heading:'Cinzel',serif;--font-body:'Lato',sans-serif;/* Spacing */ --space-xs:0.5rem;--space-sm:1rem;--space-md:2rem;--space-lg:4rem;--space-xl:6rem;/* Transitions */ --transition-fast:0.2s ease;--transition-medium:0.3s ease;--transition-slow:0.5s ease;/* Border Radius */ --radius-sm:4px;--radius-md:8px;--radius-lg:16px;}/* =========================================== Reset & Base Styles =========================================== */*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;}html{scroll-behavior:smooth;font-size:16px;}body{font-family:var(--font-body);background-color:var(--color-black);color:var(--color-text-primary);line-height:1.6;overflow-x:hidden;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;}body.modal-open{overflow:hidden;}a{color:var(--color-gold);text-decoration:none;transition:color var(--transition-fast);}a:hover{color:var(--color-gold-light);}img{max-width:100%;height:auto;display:block;}/* Prevent logo from ever displaying at natural size */img[src*="taboo-logo"],.logo img,.logo-img,.footer-logo-img{max-height:120px !important;height:120px !important;width:auto !important;max-width:220px !important;display:inline-block !important;position:relative !important;}/* =========================================== Typography =========================================== */h1,h2,h3,h4,h5,h6{font-family:var(--font-heading);font-weight:500;line-height:1.2;color:var(--color-text-primary);}h1{font-size:clamp(2.5rem,5vw,4rem);}h2{font-size:clamp(2rem,4vw,3rem);}h3{font-size:clamp(1.25rem,2vw,1.5rem);}h4{font-size:1.125rem;}p{margin-bottom:1rem;}.lead{font-size:1.25rem;font-weight:300;color:var(--color-text-primary);margin-bottom:1.5rem;}/* =========================================== Layout =========================================== */.container{width:100%;max-width:1200px;margin:0 auto;padding:0 var(--space-md);}.section{padding:var(--space-xl) 0;}.section-header{text-align:center;margin-bottom:var(--space-lg);}.section-tag{display:inline-block;font-family:var(--font-body);font-size:0.75rem;font-weight:700;letter-spacing:0.2em;text-transform:uppercase;color:var(--color-gold);margin-bottom:var(--space-sm);}.section-title{margin-bottom:var(--space-sm);}.section-description{max-width:600px;margin:0 auto;color:var(--color-text-secondary);}.section-cta{text-align:center;margin-top:var(--space-lg);}/* =========================================== Buttons =========================================== */.btn{display:inline-flex;align-items:center;justify-content:center;gap:0.5rem;font-family:var(--font-body);font-size:0.875rem;font-weight:700;letter-spacing:0.15em;text-transform:uppercase;padding:1rem 2rem;border:2px solid transparent;border-radius:var(--radius-sm);cursor:pointer;transition:all var(--transition-medium);text-decoration:none;}.btn-primary{background:var(--color-pink);color:white;border-color:var(--color-pink);}.btn-primary:hover{background:var(--color-pink-light);border-color:var(--color-pink-light);color:white;transform:translateY(-2px);box-shadow:0 4px 20px rgba(233,30,140,0.4);}.btn-ghost{background:transparent;color:var(--color-gold);border-color:var(--color-gold);}.btn-ghost:hover{background:var(--color-gold);color:var(--color-black);}.btn-large{padding:1.25rem 2.5rem;font-size:1rem;}.btn-nav{padding:0.75rem 1.5rem;font-size:0.75rem;}/* =========================================== Age Verification Modal =========================================== */.modal-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background:rgba(0,0,0,0.95);display:flex;align-items:center;justify-content:center;z-index:10000;opacity:1;visibility:visible;transition:opacity var(--transition-medium),visibility var(--transition-medium);}.modal-overlay.hidden{opacity:0;visibility:hidden;pointer-events:none;}.modal-content{background:var(--color-charcoal);padding:var(--space-lg);border-radius:var(--radius-lg);max-width:480px;width:90%;text-align:center;border:1px solid var(--color-charcoal-lighter);}.modal-icon{color:var(--color-gold);margin-bottom:var(--space-md);}.modal-content h2{font-size:1.75rem;margin-bottom:var(--space-sm);}.modal-content p{color:var(--color-text-secondary);margin-bottom:var(--space-xs);}.modal-subtext{font-size:0.875rem;}.modal-buttons{display:flex;flex-direction:column;gap:var(--space-sm);margin:var(--space-md) 0;}.modal-disclaimer{font-size:0.75rem;color:var(--color-text-muted);margin-bottom:0;}/* =========================================== Quick Exit Button =========================================== */.quick-exit{position:fixed;top:1rem;right:1rem;z-index:9999;display:flex;align-items:center;gap:0.5rem;padding:0.5rem 1rem;background:rgba(233,30,140,0.9);color:white;border-radius:var(--radius-sm);font-size:0.75rem;font-weight:700;letter-spacing:0.1em;text-transform:uppercase;text-decoration:none;transition:all var(--transition-fast);backdrop-filter:blur(10px);}.quick-exit:hover{background:var(--color-pink);color:white;transform:scale(1.05);}.quick-exit.hidden{display:none;}/* =========================================== Navigation =========================================== */.navbar{position:fixed;top:0;left:0;width:100%;z-index:1000;padding:1rem 0;background:transparent;transition:all var(--transition-medium);}.navbar.scrolled{background:rgba(10,10,10,0.95);backdrop-filter:blur(20px);padding:0.75rem 0;}.nav-container{max-width:1400px;margin:0 auto;padding:0 var(--space-md);display:flex;align-items:center;justify-content:space-between;}.logo{display:flex;align-items:center;text-decoration:none;line-height:1;flex-shrink:0;max-height:130px;overflow:hidden;}.logo-img{height:120px !important;width:auto !important;max-width:220px !important;object-fit:contain;transition:transform var(--transition-fast);}.logo:hover .logo-img{transform:scale(1.02);}.navbar.scrolled .logo-img{height:80px !important;max-width:180px !important;}.logo-text{font-family:var(--font-heading);font-size:1.5rem;font-weight:600;letter-spacing:0.2em;color:var(--color-text-primary);}.logo-accent{font-family:var(--font-body);font-size:0.625rem;font-weight:700;letter-spacing:0.4em;color:var(--color-gold);text-transform:uppercase;}.nav-menu{display:flex;align-items:center;gap:var(--space-md);list-style:none;}.nav-menu a{font-size:0.875rem;font-weight:400;letter-spacing:0.1em;text-transform:uppercase;color:var(--color-text-secondary);transition:color var(--transition-fast);}.nav-menu a:hover,.nav-menu a.active{color:var(--color-gold);}.nav-toggle{display:none;flex-direction:column;gap:5px;background:none;border:none;cursor:pointer;padding:0.5rem;}.nav-toggle span{display:block;width:24px;height:2px;background:var(--color-text-primary);transition:all var(--transition-fast);}/* =========================================== Hero Section =========================================== */.hero{position:relative;height:100vh;min-height:600px;display:flex;align-items:center;justify-content:center;overflow:hidden;}.hero-video-container{position:absolute;top:0;left:0;width:100%;height:100%;}.hero-video{width:100%;height:100%;object-fit:cover;}.hero-video-iframe{position:absolute;top:50%;left:50%;width:100vw;height:100vh;min-width:177.78vh;/* 16:9 aspect ratio */ min-height:56.25vw;transform:translate(-50%,-50%);pointer-events:none;border:0;}.hero-overlay{position:absolute;top:0;left:0;width:100%;height:100%;background:linear-gradient( to bottom,rgba(10,10,10,0.5) 0%,rgba(10,10,10,0.7) 50%,rgba(10,10,10,0.9) 100% );}.hero-content{position:relative;z-index:2;text-align:center;max-width:800px;padding:0 var(--space-md);}.hero-title{font-size:clamp(3rem,8vw,5rem);font-weight:400;letter-spacing:0.05em;margin-bottom:var(--space-md);animation:fadeInUp 1s ease-out;}.hero-subtitle{font-size:clamp(1rem,2vw,1.25rem);font-weight:300;color:var(--color-text-secondary);margin-bottom:var(--space-lg);animation:fadeInUp 1s ease-out 0.2s both;}.hero .btn{animation:fadeInUp 1s ease-out 0.4s both;}.scroll-indicator{position:absolute;bottom:2rem;left:50%;transform:translateX(-50%);display:flex;flex-direction:column;align-items:center;gap:0.5rem;color:var(--color-text-muted);font-size:0.75rem;letter-spacing:0.2em;text-transform:uppercase;animation:pulse 2s infinite;}@keyframes fadeInUp{from{opacity:0;transform:translateY(30px);}to{opacity:1;transform:translateY(0);}}@keyframes pulse{0%,100%{opacity:0.5;}50%{opacity:1;}}/* =========================================== Philosophy Section =========================================== */.section-philosophy{background:var(--color-charcoal);}.philosophy-content{display:grid;grid-template-columns:1fr;gap:var(--space-lg);}.philosophy-text{max-width:600px;margin:0 auto;text-align:center;}.philosophy-text p{color:var(--color-text-secondary);}.philosophy-features{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:var(--space-md);}.feature-card{background:var(--color-charcoal-light);padding:var(--space-md);border-radius:var(--radius-md);text-align:center;border:1px solid var(--color-charcoal-lighter);transition:all var(--transition-medium);}.feature-card:hover{border-color:var(--color-gold);transform:translateY(-4px);}.feature-icon{color:var(--color-gold);margin-bottom:var(--space-sm);}.feature-card h3{font-family:var(--font-body);font-size:1rem;font-weight:700;letter-spacing:0.1em;text-transform:uppercase;margin-bottom:0.5rem;}.feature-card p{font-size:0.875rem;color:var(--color-text-secondary);margin-bottom:0;}/* =========================================== Experience Section =========================================== */.experience-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(320px,1fr));gap:var(--space-md);}.experience-card{position:relative;border-radius:var(--radius-md);overflow:hidden;min-height:400px;display:flex;flex-direction:column;justify-content:flex-end;}.experience-image{position:absolute;top:0;left:0;width:100%;height:100%;background-size:cover;background-position:center;background-color:var(--color-charcoal);transition:transform var(--transition-slow);}.experience-card:hover .experience-image{transform:scale(1.05);}.experience-overlay{position:absolute;top:0;left:0;width:100%;height:100%;background:linear-gradient( to top,rgba(10,10,10,0.95) 0%,rgba(10,10,10,0.3) 50%,rgba(10,10,10,0.1) 100% );}.experience-content{position:relative;z-index:2;padding:var(--space-md);}.experience-tag{display:inline-block;font-size:0.625rem;font-weight:700;letter-spacing:0.2em;text-transform:uppercase;color:var(--color-gold);margin-bottom:0.5rem;}.experience-content h3{margin-bottom:0.5rem;}.experience-content p{font-size:0.875rem;color:var(--color-text-secondary);margin-bottom:0;}/* =========================================== Destinations Section =========================================== */.section-destinations{background:var(--color-charcoal);}.destinations-preview{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:var(--space-md);}.destination-card{position:relative;border-radius:var(--radius-md);overflow:hidden;cursor:pointer;transition:transform var(--transition-medium);}.destination-card:hover{transform:translateY(-8px);}.destination-image{position:relative;height:300px;background-size:cover;background-position:center;background-color:var(--color-charcoal);transition:transform var(--transition-slow);}.destination-card:hover .destination-image{transform:scale(1.05);}.destination-video{position:relative;height:300px;overflow:hidden;background-color:var(--color-charcoal);}.destination-video iframe{position:absolute;top:50%;left:50%;width:200%;height:200%;transform:translate(-50%,-50%);pointer-events:none;border:0;}.destination-card-video:hover .destination-video iframe{pointer-events:auto;}.destination-overlay{position:absolute;top:0;left:0;width:100%;height:100%;background:linear-gradient( to top,rgba(10,10,10,0.9) 0%,rgba(10,10,10,0.2) 60% );}.destination-vibe{position:absolute;top:1rem;right:1rem;font-size:0.625rem;font-weight:700;letter-spacing:0.15em;text-transform:uppercase;padding:0.5rem 0.75rem;background:rgba(61,218,215,0.9);color:var(--color-black);border-radius:var(--radius-sm);}.destination-content{position:absolute;bottom:0;left:0;width:100%;padding:var(--space-md);z-index:2;}.destination-content h3{font-size:1.25rem;margin-bottom:0.25rem;}.destination-content p{font-size:0.875rem;color:var(--color-text-secondary);margin-bottom:0;}/* =========================================== Trust Bar =========================================== */.trust-bar{padding:var(--space-lg) 0;background:var(--color-black);border-top:1px solid var(--color-charcoal-lighter);border-bottom:1px solid var(--color-charcoal-lighter);}.trust-text{text-align:center;font-size:0.75rem;font-weight:700;letter-spacing:0.2em;text-transform:uppercase;color:var(--color-text-muted);margin-bottom:var(--space-md);}.trust-logos{display:flex;flex-wrap:wrap;justify-content:center;align-items:center;gap:var(--space-lg);}.partner-logo{font-family:var(--font-heading);font-size:1rem;font-weight:500;letter-spacing:0.15em;color:var(--color-gold);opacity:0.6;transition:opacity var(--transition-fast);}.partner-logo:hover{opacity:1;}/* =========================================== CTA Section =========================================== */.section-cta-main{background:linear-gradient( 135deg,var(--color-charcoal) 0%,var(--color-charcoal-light) 100% );text-align:center;}.cta-content h2{margin-bottom:var(--space-sm);}.cta-content p{color:var(--color-text-secondary);margin-bottom:var(--space-md);}/* =========================================== Footer =========================================== */.footer{background:var(--color-black);padding:var(--space-lg) 0 var(--space-md);border-top:1px solid var(--color-charcoal-lighter);}.footer-content{display:grid;grid-template-columns:1fr;gap:var(--space-lg);margin-bottom:var(--space-lg);}.footer-logo-img{height:50px !important;width:auto !important;max-width:160px !important;object-fit:contain;}.footer-brand p{color:var(--color-text-muted);font-size:0.875rem;margin-top:var(--space-sm);}.footer-links{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:var(--space-md);}.footer-column h4{font-family:var(--font-body);font-size:0.75rem;font-weight:700;letter-spacing:0.15em;text-transform:uppercase;color:var(--color-gold);margin-bottom:var(--space-sm);}.footer-column ul{list-style:none;}.footer-column li{margin-bottom:0.5rem;}.footer-column a{font-size:0.875rem;color:var(--color-text-secondary);}.footer-column a:hover{color:var(--color-gold);}.footer-bottom{padding-top:var(--space-md);border-top:1px solid var(--color-charcoal-lighter);display:flex;flex-wrap:wrap;justify-content:space-between;align-items:center;gap:var(--space-sm);}.footer-bottom p{font-size:0.75rem;color:var(--color-text-muted);margin-bottom:0;}.footer-secure{display:flex;align-items:center;gap:0.5rem;color:var(--color-gold) !important;}/* =========================================== Responsive Design =========================================== */@media (min-width:768px){.modal-buttons{flex-direction:row;justify-content:center;}.philosophy-content{grid-template-columns:1fr 1fr;align-items:center;}.philosophy-text{text-align:left;margin:0;}.footer-content{grid-template-columns:1fr 2fr;}}@media (max-width:768px){.nav-toggle{display:flex;}.nav-menu{position:fixed;top:0;right:-100%;width:80%;max-width:320px;height:100vh;background:var(--color-charcoal);flex-direction:column;justify-content:center;align-items:center;gap:var(--space-md);transition:right var(--transition-medium);}.nav-menu.active{right:0;}.nav-menu a{font-size:1.25rem;}.quick-exit{top:auto;bottom:1rem;right:1rem;}.hero{min-height:100vh;}.hero-title{font-size:2.5rem;}.section{padding:var(--space-lg) 0;}.trust-logos{gap:var(--space-md);}.partner-logo{font-size:0.875rem;}}/* =========================================== Form Styles (for contact page) =========================================== */.form-group{margin-bottom:var(--space-md);}.form-label{display:block;font-size:0.75rem;font-weight:700;letter-spacing:0.15em;text-transform:uppercase;color:var(--color-text-secondary);margin-bottom:0.5rem;}.form-input,.form-textarea,.form-select{width:100%;padding:1rem;background:var(--color-charcoal-light);border:1px solid var(--color-charcoal-lighter);border-radius:var(--radius-sm);color:var(--color-text-primary);font-family:var(--font-body);font-size:1rem;transition:border-color var(--transition-fast);}.form-input:focus,.form-textarea:focus,.form-select:focus{outline:none;border-color:var(--color-gold);}.form-textarea{min-height:150px;resize:vertical;}.form-select{appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24' viewBox='0 0 24 24' fill='none' stroke='%23B0B0B0' stroke-width='2'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 1rem center;cursor:pointer;}.form-select option{background:var(--color-charcoal);}.checkbox-group{display:flex;align-items:flex-start;gap:0.75rem;}.checkbox-group input[type="checkbox"]{width:20px;height:20px;margin-top:0.25rem;accent-color:var(--color-gold);}.checkbox-label{font-size:0.875rem;color:var(--color-text-secondary);}.form-disclaimer{display:flex;align-items:center;gap:0.5rem;font-size:0.75rem;color:var(--color-text-muted);margin-top:var(--space-md);}.form-disclaimer svg{color:var(--color-gold);flex-shrink:0;}/* =========================================== Page Headers (for inner pages) =========================================== */.page-header{padding:calc(80px + var(--space-xl)) 0 var(--space-lg);background:linear-gradient( to bottom,var(--color-charcoal) 0%,var(--color-black) 100% );text-align:center;}.page-header .section-tag{margin-bottom:var(--space-sm);}.page-header h1{margin-bottom:var(--space-sm);}.page-header p{max-width:600px;margin:0 auto;color:var(--color-text-secondary);}/* =========================================== Etiquette Page Styles =========================================== */.etiquette-intro{max-width:800px;margin:0 auto var(--space-lg);text-align:center;}.intro-video-container{margin-bottom:var(--space-md);border-radius:var(--radius-lg);overflow:hidden;box-shadow:0 20px 60px rgba(0,0,0,0.4);}.intro-video{width:100%;height:auto;display:block;}.etiquette-section{background:var(--color-charcoal);border-radius:var(--radius-md);padding:var(--space-md);margin-bottom:var(--space-md);border:1px solid var(--color-charcoal-lighter);}.etiquette-section h3{display:flex;align-items:center;gap:0.75rem;margin-bottom:var(--space-sm);color:var(--color-gold);}.etiquette-section h3 svg{flex-shrink:0;}.etiquette-section p,.etiquette-section li{color:var(--color-text-secondary);}.etiquette-section ul{list-style:none;padding-left:0;}.etiquette-section li{padding-left:1.5rem;position:relative;margin-bottom:0.5rem;}.etiquette-section li::before{content:"•";color:var(--color-gold);position:absolute;left:0;}/* Glossary */.glossary-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:var(--space-md);margin-top:var(--space-md);}.glossary-item{background:var(--color-charcoal-light);padding:var(--space-sm);border-radius:var(--radius-sm);border-left:3px solid var(--color-gold);}.glossary-term{font-weight:700;color:var(--color-text-primary);margin-bottom:0.25rem;}.glossary-definition{font-size:0.875rem;color:var(--color-text-secondary);margin-bottom:0;}/* =========================================== Collection Page Styles =========================================== */.collection-filters{display:flex;flex-wrap:wrap;justify-content:center;gap:var(--space-sm);margin-bottom:var(--space-lg);}.filter-btn{padding:0.5rem 1rem;background:transparent;border:1px solid var(--color-charcoal-lighter);border-radius:var(--radius-sm);color:var(--color-text-secondary);font-family:var(--font-body);font-size:0.75rem;font-weight:700;letter-spacing:0.1em;text-transform:uppercase;cursor:pointer;transition:all var(--transition-fast);}.filter-btn:hover,.filter-btn.active{background:var(--color-gold);border-color:var(--color-gold);color:var(--color-black);}.destination-detail{display:grid;grid-template-columns:1fr;gap:var(--space-lg);}@media (min-width:768px){.destination-detail{grid-template-columns:1fr 1fr;}}.destination-detail-image{border-radius:var(--radius-md);overflow:hidden;height:400px;background-color:var(--color-charcoal);}.destination-detail-image img{width:100%;height:100%;object-fit:cover;}.destination-detail-content h3{color:var(--color-gold);margin-bottom:var(--space-sm);}.destination-detail-content p{color:var(--color-text-secondary);}.destination-features{display:flex;flex-wrap:wrap;gap:0.5rem;margin:var(--space-sm) 0;}.destination-feature{display:inline-block;padding:0.25rem 0.75rem;background:var(--color-charcoal-lighter);border-radius:var(--radius-sm);font-size:0.75rem;color:var(--color-text-secondary);}/* =========================================== Animations =========================================== */.fade-in{opacity:0;transform:translateY(20px);transition:opacity 0.6s ease,transform 0.6s ease;}.fade-in.visible{opacity:1;transform:translateY(0);}/* =========================================== Photo Gallery =========================================== */.photo-gallery{margin-top:var(--space-lg);}.gallery-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--space-sm);}@media (max-width:992px){.gallery-grid{grid-template-columns:repeat(2,1fr);}}@media (max-width:576px){.gallery-grid{grid-template-columns:1fr;}}.gallery-item{position:relative;aspect-ratio:4/3;overflow:hidden;border-radius:var(--radius-md);cursor:pointer;}.gallery-item img{width:100%;height:100%;object-fit:cover;transition:transform var(--transition-medium);}.gallery-item:hover img{transform:scale(1.05);}.gallery-caption{position:absolute;bottom:0;left:0;right:0;padding:var(--space-sm);background:linear-gradient(transparent,rgba(0,0,0,0.8));color:var(--color-text-primary);font-size:0.875rem;font-weight:500;opacity:0;transform:translateY(10px);transition:opacity var(--transition-medium),transform var(--transition-medium);}.gallery-item:hover .gallery-caption{opacity:1;transform:translateY(0);}/* =========================================== Featured Cruises & Promotions =========================================== */.section-cruises{background:var(--color-charcoal);}.promo-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem;}@media (max-width:992px){.promo-grid{grid-template-columns:repeat(2,1fr);}}@media (max-width:576px){.promo-grid{grid-template-columns:1fr;gap:1.25rem;}}.promo-card{position:relative;display:flex;flex-direction:column;background:var(--color-charcoal-light);border-radius:var(--radius-lg);overflow:hidden;text-decoration:none;transition:transform var(--transition-medium),box-shadow var(--transition-medium);border:1px solid rgba(255,255,255,0.05);}.promo-card:hover{transform:translateY(-8px);box-shadow:0 25px 50px rgba(0,0,0,0.5);border-color:rgba(255,255,255,0.1);}.promo-card-image{position:relative;width:100%;height:180px;overflow:hidden;}.promo-card-image::after{content:'';position:absolute;bottom:0;left:0;right:0;height:60px;background:linear-gradient(to top,var(--color-charcoal-light),transparent);pointer-events:none;}.promo-card-image img{width:100%;height:100%;object-fit:cover;transition:transform var(--transition-slow);}.promo-card:hover .promo-card-image img{transform:scale(1.08);}.promo-badge{position:absolute;top:0.75rem;left:0.75rem;padding:0.35rem 0.75rem;background:var(--color-pink);color:white;font-size:0.625rem;font-weight:700;letter-spacing:0.1em;text-transform:uppercase;border-radius:4px;z-index:2;box-shadow:0 2px 8px rgba(0,0,0,0.3);}.promo-card.promo-featured .promo-badge{background:var(--color-turquoise);color:var(--color-black);}.promo-card.promo-deal .promo-badge{background:linear-gradient(135deg,var(--color-gold),var(--color-gold-dark));color:var(--color-black);}.promo-content{padding:1.25rem 1.5rem 1.5rem;flex:1;display:flex;flex-direction:column;}.promo-brand{display:block;font-size:0.65rem;font-weight:700;letter-spacing:0.2em;text-transform:uppercase;color:var(--color-gold);margin-bottom:0.5rem;}.promo-content h3{font-family:var(--font-heading);font-size:1.1rem;font-weight:500;color:var(--color-text-primary);margin-bottom:0.75rem;line-height:1.35;}.promo-details{font-size:0.8rem;color:var(--color-text-secondary);margin-bottom:0.35rem;}.promo-route{font-size:0.75rem;color:var(--color-text-muted);margin-bottom:1rem;line-height:1.5;flex:1;}.promo-cta{display:inline-flex;align-items:center;gap:0.35rem;font-size:0.7rem;font-weight:700;letter-spacing:0.12em;text-transform:uppercase;color:var(--color-gold);transition:all var(--transition-fast);margin-top:auto;}.promo-cta::after{content:'→';transition:transform var(--transition-fast);}.promo-card:hover .promo-cta{color:var(--color-gold-light);}.promo-card:hover .promo-cta::after{transform:translateX(4px);}/* =========================================== Utility Classes =========================================== */.text-center{text-align:center;}.text-gold{color:var(--color-gold);}.mb-0{margin-bottom:0;}.mt-md{margin-top:var(--space-md);}