/* ============================================================
   CARNIVAL CRUISE LINE — MAIN STYLESHEET v3
   Theme: Carnival.com inspired — clean, white, navy + red
   ============================================================ */

@import url('https://fonts.googleapis.com/css2?family=Source+Sans+3:wght@300;400;600;700;900&family=Playfair+Display:wght@700&display=swap');

:root {
    --navy:      #003087;
    --navy-dark: #00205b;
    --navy-mid:  #0a3d91;
    --red:       #E31837;
    --red-dark:  #c0122e;
    --white:     #ffffff;
    --off-white: #f8f9fc;
    --light-grey:#eef1f7;
    --mid-grey:  #c8d0e0;
    --text-dark: #1a1a2e;
    --text-mid:  #4a5568;
    --text-light:#718096;
    --gold:      #c9a84c;
    --gold-light:#e8c97e;
    --shadow-sm: 0 2px 8px rgba(0,48,135,0.08);
    --shadow-md: 0 4px 20px rgba(0,48,135,0.12);
    --shadow-lg: 0 8px 40px rgba(0,48,135,0.16);
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:'Source Sans 3',Arial,sans-serif;color:var(--text-dark);background:#fff;min-height:100vh;display:flex;flex-direction:column;overflow-x:hidden}

/* ---- SCROLLBAR ---- */
::-webkit-scrollbar{width:6px}
::-webkit-scrollbar-track{background:#f0f2f8}
::-webkit-scrollbar-thumb{background:var(--navy);border-radius:3px}

/* ============================================================
   TYPOGRAPHY
   ============================================================ */
h1,h2,h3{font-family:'Source Sans 3',Arial,sans-serif;font-weight:900;color:var(--navy)}
.display-font{font-family:'Playfair Display',serif}

/* ============================================================
   NAVBAR
   ============================================================ */
.navbar{background:#fff;border-bottom:3px solid var(--red);box-shadow:var(--shadow-sm);position:fixed;top:0;left:0;right:0;z-index:100}
.navbar-inner{max-width:1200px;margin:0 auto;padding:0 24px;height:70px;display:flex;align-items:center;justify-content:space-between}
.navbar-brand{display:flex;align-items:center;gap:10px;text-decoration:none}
.navbar-brand .brand-name{font-size:1.5rem;font-weight:900;color:var(--navy);letter-spacing:-0.02em}
.navbar-brand .brand-name span{color:var(--red)}
.navbar-links{display:flex;align-items:center;gap:32px}
.navbar-links a{color:var(--text-mid);text-decoration:none;font-weight:600;font-size:0.9rem;transition:color 0.2s}
.navbar-links a:hover{color:var(--navy)}
.navbar-cta{display:flex;align-items:center;gap:10px}

/* ============================================================
   BUTTONS
   ============================================================ */
.btn-red{display:inline-flex;align-items:center;justify-content:center;gap:8px;background:var(--red);color:#fff;font-weight:700;font-size:0.9rem;padding:12px 28px;border-radius:6px;text-decoration:none;border:none;cursor:pointer;transition:all 0.2s;letter-spacing:0.02em}
.btn-red:hover{background:var(--red-dark);transform:translateY(-1px);box-shadow:0 4px 16px rgba(227,24,55,0.35)}

.btn-navy{display:inline-flex;align-items:center;justify-content:center;gap:8px;background:var(--navy);color:#fff;font-weight:700;font-size:0.9rem;padding:12px 28px;border-radius:6px;text-decoration:none;border:none;cursor:pointer;transition:all 0.2s}
.btn-navy:hover{background:var(--navy-dark);transform:translateY(-1px);box-shadow:var(--shadow-md)}

.btn-outline-navy{display:inline-flex;align-items:center;justify-content:center;gap:8px;background:transparent;color:var(--navy);font-weight:700;font-size:0.9rem;padding:11px 27px;border-radius:6px;text-decoration:none;border:2px solid var(--navy);cursor:pointer;transition:all 0.2s}
.btn-outline-navy:hover{background:var(--navy);color:#fff}

.btn-outline-white{display:inline-flex;align-items:center;justify-content:center;gap:8px;background:transparent;color:#fff;font-weight:700;font-size:0.9rem;padding:11px 27px;border-radius:6px;text-decoration:none;border:2px solid rgba(255,255,255,0.7);cursor:pointer;transition:all 0.2s}
.btn-outline-white:hover{background:rgba(255,255,255,0.15);border-color:#fff}

.btn-gold{display:inline-flex;align-items:center;justify-content:center;gap:8px;background:linear-gradient(135deg,var(--gold),var(--gold-light));color:#fff;font-weight:700;font-size:0.9rem;padding:12px 28px;border-radius:6px;text-decoration:none;border:none;cursor:pointer;transition:all 0.2s;box-shadow:0 4px 16px rgba(201,168,76,0.3)}
.btn-gold:hover{transform:translateY(-1px);box-shadow:0 6px 24px rgba(201,168,76,0.45)}

.btn-sm{padding:8px 18px;font-size:0.82rem}
.btn-lg{padding:16px 36px;font-size:1rem}
.btn-full{width:100%}

/* ============================================================
   HERO (dark — keeps the Carnival Millions image)
   ============================================================ */
.hero{position:relative;min-height:92vh;display:flex;align-items:center;overflow:hidden;padding-top:70px}
.hero-img{position:absolute;inset:0;z-index:0}
.hero-img img{width:100%;height:100%;object-fit:cover;object-position:center}
.hero-overlay{position:absolute;inset:0;background:linear-gradient(135deg,rgba(0,32,91,0.82) 0%,rgba(0,48,135,0.55) 60%,rgba(0,32,91,0.7) 100%)}
.hero-bottom-fade{position:absolute;bottom:0;left:0;right:0;height:120px;background:linear-gradient(to bottom,transparent,#fff)}
.hero-content{position:relative;z-index:10;max-width:1200px;margin:0 auto;padding:60px 24px}
.hero-badge{display:inline-flex;align-items:center;gap:8px;background:rgba(227,24,55,0.2);border:1px solid rgba(227,24,55,0.5);border-radius:4px;padding:6px 14px;margin-bottom:24px;color:#fff;font-size:0.78rem;font-weight:700;letter-spacing:0.1em;text-transform:uppercase}
.hero-title{font-size:clamp(2.5rem,6vw,4.5rem);font-weight:900;color:#fff;line-height:1.1;margin-bottom:20px}
.hero-title .highlight{color:var(--gold-light)}
.hero-sub{color:rgba(255,255,255,0.8);font-size:1.1rem;line-height:1.6;max-width:540px;margin-bottom:36px}
.hero-stats{display:flex;flex-wrap:wrap;gap:40px;margin-top:48px}
.hero-stat-value{font-size:2rem;font-weight:900;color:var(--gold-light)}
.hero-stat-label{color:rgba(255,255,255,0.65);font-size:0.82rem;margin-top:2px}

/* Wave divider */
.wave-divider{display:block;width:100%;overflow:hidden;line-height:0;margin-top:-2px}
.wave-divider svg{display:block;width:100%}

/* ============================================================
   SECTIONS
   ============================================================ */
.section{padding:72px 0}
.section-grey{background:var(--off-white)}
.section-navy{background:var(--navy)}
.section-inner{max-width:1200px;margin:0 auto;padding:0 24px}

.section-tag{display:inline-block;background:rgba(227,24,55,0.1);color:var(--red);font-size:0.75rem;font-weight:700;letter-spacing:0.1em;text-transform:uppercase;padding:4px 12px;border-radius:4px;margin-bottom:12px}
.section-title{font-size:clamp(1.6rem,4vw,2.4rem);font-weight:900;color:var(--navy);margin-bottom:12px}
.section-sub{color:var(--text-mid);font-size:1rem;line-height:1.7;max-width:560px}

/* ============================================================
   CARDS
   ============================================================ */
.card{background:#fff;border-radius:10px;box-shadow:var(--shadow-sm);border:1px solid var(--light-grey);overflow:hidden;transition:all 0.25s}
.card:hover{box-shadow:var(--shadow-md);transform:translateY(-3px)}

.card-cruise{background:#fff;border-radius:10px;box-shadow:var(--shadow-sm);border:1px solid var(--light-grey);overflow:hidden;transition:all 0.25s;display:flex;flex-direction:column}
.card-cruise:hover{box-shadow:var(--shadow-lg);transform:translateY(-4px)}
.card-cruise img{width:100%;height:180px;object-fit:cover;transition:transform 0.4s}
.card-cruise:hover img{transform:scale(1.05)}
.card-cruise-body{padding:20px;flex:1;display:flex;flex-direction:column}
.card-cruise h3{font-size:1rem;font-weight:700;color:var(--navy);margin-bottom:6px}
.card-cruise p{color:var(--text-light);font-size:0.82rem;line-height:1.5;flex:1;margin-bottom:14px}

/* Dashboard card */
.dash-card{background:#fff;border-radius:12px;box-shadow:var(--shadow-sm);border:1px solid var(--light-grey);padding:28px}

/* Stat card */
.stat-card{background:#fff;border-radius:10px;box-shadow:var(--shadow-sm);border:1px solid var(--light-grey);padding:24px;transition:all 0.25s}
.stat-card:hover{border-color:var(--navy);box-shadow:var(--shadow-md)}
.stat-value{font-size:2rem;font-weight:900;color:var(--navy)}
.stat-label{color:var(--text-light);font-size:0.82rem;margin-top:4px}

/* ============================================================
   FORMS
   ============================================================ */
.form-group{margin-bottom:20px}
.form-label{display:block;font-size:0.8rem;font-weight:700;color:var(--text-mid);margin-bottom:6px;text-transform:uppercase;letter-spacing:0.05em}
.form-input{width:100%;background:#fff;border:2px solid var(--mid-grey);border-radius:6px;padding:12px 14px;color:var(--text-dark);font-size:0.92rem;font-family:inherit;transition:all 0.2s;outline:none}
.form-input:focus{border-color:var(--navy);box-shadow:0 0 0 3px rgba(0,48,135,0.1)}
.form-input::placeholder{color:var(--mid-grey)}
select.form-input option{background:#fff;color:var(--text-dark)}

/* ============================================================
   FLASH MESSAGES
   ============================================================ */
.flash{border-radius:8px;padding:14px 18px;font-size:0.9rem;margin-bottom:20px}
.flash-success{background:#f0fff4;border:1px solid #9ae6b4;color:#276749}
.flash-error{background:#fff5f5;border:1px solid #feb2b2;color:#c53030}
.flash-info{background:#ebf8ff;border:1px solid #90cdf4;color:#2b6cb0}
.flash-warning{background:#fffbeb;border:1px solid #f6e05e;color:#975a16}

/* ============================================================
   DASHBOARD SIDEBAR
   ============================================================ */
.sidebar{background:var(--navy);min-height:100vh;width:240px;flex-shrink:0;display:flex;flex-direction:column;padding:24px 0;position:fixed;top:0;left:0;height:100%;z-index:50}
.sidebar-brand{padding:0 20px 24px;border-bottom:1px solid rgba(255,255,255,0.1);margin-bottom:16px}
.sidebar-brand .brand{font-size:1.2rem;font-weight:900;color:#fff}
.sidebar-brand .brand span{color:var(--red)}
.sidebar-link{display:flex;align-items:center;gap:12px;padding:11px 20px;color:rgba(255,255,255,0.7);text-decoration:none;font-size:0.88rem;font-weight:600;transition:all 0.2s;border-left:3px solid transparent}
.sidebar-link:hover,.sidebar-link.active{background:rgba(255,255,255,0.1);color:#fff;border-left-color:var(--red)}
.sidebar-link .icon{width:18px;text-align:center;font-size:1rem}
.sidebar-section{padding:8px 20px;font-size:0.7rem;font-weight:700;color:rgba(255,255,255,0.35);text-transform:uppercase;letter-spacing:0.1em;margin-top:8px}

/* ============================================================
   COUNTDOWN TIMER
   ============================================================ */
.countdown-box{background:var(--navy);border-radius:10px;padding:24px;color:#fff;text-align:center}
.countdown-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin-top:16px}
.countdown-unit{background:rgba(255,255,255,0.1);border-radius:8px;padding:12px 8px}
.countdown-num{font-size:1.8rem;font-weight:900;color:#fff;line-height:1}
.countdown-label{font-size:0.68rem;color:rgba(255,255,255,0.6);text-transform:uppercase;letter-spacing:0.08em;margin-top:4px}

/* ============================================================
   MODAL
   ============================================================ */
.modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,0.55);z-index:1000;display:flex;align-items:center;justify-content:center;padding:20px;opacity:0;visibility:hidden;transition:all 0.3s}
.modal-overlay.active{opacity:1;visibility:visible}
.modal-box{background:#fff;border-radius:12px;padding:40px;max-width:500px;width:100%;transform:scale(0.95);transition:transform 0.3s;box-shadow:var(--shadow-lg)}
.modal-overlay.active .modal-box{transform:scale(1)}
.modal-title{font-size:1.4rem;font-weight:900;color:var(--navy);margin-bottom:8px}

/* ============================================================
   WINNER PAGE
   ============================================================ */
.winner-hero{background:linear-gradient(135deg,var(--navy-dark) 0%,var(--navy) 100%);min-height:100vh;display:flex;align-items:center;justify-content:center;padding:40px 24px}
.winner-card{background:#fff;border-radius:16px;padding:48px;max-width:560px;width:100%;text-align:center;box-shadow:0 0 80px rgba(201,168,76,0.3)}
.winner-id{background:linear-gradient(135deg,#fffbeb,#fef3c7);border:2px solid var(--gold);border-radius:8px;padding:20px;margin:24px 0}
.winner-id-code{font-size:1.6rem;font-weight:900;color:var(--navy);letter-spacing:0.1em;font-family:monospace}

/* ============================================================
   TABLE
   ============================================================ */
.table-wrap{overflow-x:auto;border-radius:10px;box-shadow:var(--shadow-sm);border:1px solid var(--light-grey)}
table{width:100%;border-collapse:collapse;font-size:0.88rem}
thead{background:var(--navy)}
thead th{padding:14px 16px;text-align:left;color:#fff;font-weight:700;font-size:0.78rem;text-transform:uppercase;letter-spacing:0.06em;white-space:nowrap}
tbody tr{border-bottom:1px solid var(--light-grey);transition:background 0.15s}
tbody tr:last-child{border-bottom:none}
tbody tr:hover{background:var(--off-white)}
tbody td{padding:14px 16px;color:var(--text-dark);vertical-align:middle}

/* Status badges */
.badge{display:inline-block;padding:3px 10px;border-radius:20px;font-size:0.75rem;font-weight:700}
.badge-green{background:#f0fff4;color:#276749;border:1px solid #9ae6b4}
.badge-red{background:#fff5f5;color:#c53030;border:1px solid #feb2b2}
.badge-yellow{background:#fffbeb;color:#975a16;border:1px solid #f6e05e}
.badge-blue{background:#ebf8ff;color:#2b6cb0;border:1px solid #90cdf4}
.badge-grey{background:#f7fafc;color:#718096;border:1px solid #e2e8f0}
.badge-gold{background:#fffbeb;color:#b7791f;border:1px solid var(--gold)}

/* ============================================================
   ADMIN PANEL
   ============================================================ */
.admin-layout{display:flex;min-height:100vh;background:var(--off-white)}
.admin-sidebar{background:var(--navy-dark);width:220px;flex-shrink:0;min-height:100vh;padding:0;position:fixed;top:0;left:0;height:100%;z-index:50;display:flex;flex-direction:column}
.admin-main{margin-left:220px;flex:1;padding:32px;min-height:100vh}
.admin-topbar{background:#fff;border-radius:10px;box-shadow:var(--shadow-sm);padding:16px 24px;margin-bottom:28px;display:flex;align-items:center;justify-content:space-between}
.admin-topbar h1{font-size:1.4rem;font-weight:900;color:var(--navy)}

/* ============================================================
   NOTIFICATIONS BELL
   ============================================================ */
.notif-bell{position:relative;cursor:pointer}
.notif-badge{position:absolute;top:-6px;right:-6px;background:var(--red);color:#fff;border-radius:50%;width:18px;height:18px;font-size:0.65rem;font-weight:700;display:flex;align-items:center;justify-content:center}

/* ============================================================
   ANIMATIONS
   ============================================================ */
@keyframes fadeInUp{from{opacity:0;transform:translateY(24px)}to{opacity:1;transform:translateY(0)}}
@keyframes fadeIn{from{opacity:0}to{opacity:1}}
@keyframes spin{to{transform:rotate(360deg)}}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:0.5}}
@keyframes confettiFall{0%{transform:translateY(-10px) rotate(0deg);opacity:1}100%{transform:translateY(100vh) rotate(720deg);opacity:0}}

.animate-up{animation:fadeInUp 0.6s ease forwards}
.animate-in{animation:fadeIn 0.4s ease forwards}
.delay-1{animation-delay:0.1s;opacity:0}
.delay-2{animation-delay:0.2s;opacity:0}
.delay-3{animation-delay:0.3s;opacity:0}
.delay-4{animation-delay:0.4s;opacity:0}
.spin{animation:spin 1s linear infinite}
.confetti-piece{position:fixed;width:8px;height:8px;top:-10px;animation:confettiFall linear forwards;pointer-events:none;z-index:9999}

/* ============================================================
   FOOTER
   ============================================================ */
.footer{background:var(--navy-dark);color:#fff;padding:56px 0 32px}
.footer-inner{max-width:1200px;margin:0 auto;padding:0 24px}
.footer-brand{font-size:1.6rem;font-weight:900;color:#fff;margin-bottom:8px}
.footer-brand span{color:var(--red)}
.footer-tagline{color:rgba(255,255,255,0.5);font-size:0.85rem;margin-bottom:24px}
.footer-col h4{font-size:0.78rem;font-weight:700;text-transform:uppercase;letter-spacing:0.1em;color:rgba(255,255,255,0.5);margin-bottom:14px}
.footer-col a{display:block;color:rgba(255,255,255,0.7);text-decoration:none;font-size:0.88rem;margin-bottom:8px;transition:color 0.2s}
.footer-col a:hover{color:#fff}
.footer-bottom{border-top:1px solid rgba(255,255,255,0.1);margin-top:40px;padding-top:24px;display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:12px}
.footer-bottom p{color:rgba(255,255,255,0.4);font-size:0.8rem}

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media(max-width:1024px){
    .admin-sidebar{transform:translateX(-100%);transition:transform 0.3s}
    .admin-sidebar.open{transform:translateX(0)}
    .admin-main{margin-left:0}
    .sidebar{transform:translateX(-100%);transition:transform 0.3s;z-index:200}
    .sidebar.open{transform:translateX(0)}
    #sidebar-toggle{display:flex!important}
    #sidebar-overlay{display:none}
    .sidebar.open ~ #sidebar-overlay{display:block}
}
@media(max-width:768px){
    .hero-title{font-size:2.2rem}
    .hero-stats{gap:24px}
    .navbar-links{display:none}
    .section{padding:48px 0}
    .countdown-num{font-size:1.4rem}
}
@media(max-width:480px){
    .hero-title{font-size:1.9rem}
    .btn-lg{padding:14px 24px;font-size:0.95rem}
}

/* ============================================================
   MOBILE RESPONSIVENESS — EXTENDED
   ============================================================ */

/* Footer grid: 4 cols -> 2 cols -> 1 col */
.footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:40px}
@media(max-width:900px){
    .footer-grid{grid-template-columns:1fr 1fr;gap:28px}
}
@media(max-width:600px){
    .footer-grid{grid-template-columns:1fr;gap:20px}
    .footer-bottom{flex-direction:column;text-align:center}
}

/* Tables: horizontal scroll on mobile */
.table-wrap{overflow-x:auto;-webkit-overflow-scrolling:touch}
@media(max-width:768px){
    table{min-width:500px}
    .admin-main{padding:16px!important}
    .admin-topbar{padding:12px 16px;flex-wrap:wrap;gap:10px}
    .admin-topbar h1{font-size:1.1rem}
}

/* Stat cards: 2-col on mobile */
@media(max-width:600px){
    .stat-card-grid{grid-template-columns:1fr 1fr!important}
    .dash-card{padding:18px}
    .hero-content{padding:40px 16px}
    .section-inner{padding:0 16px}
    .navbar-inner{padding:0 16px}
    .countdown-grid{gap:8px}
    .countdown-num{font-size:1.2rem}
}

/* Admin sidebar toggle on mobile */
@media(max-width:768px){
    .admin-sidebar{transform:translateX(-100%);transition:transform 0.3s;z-index:200}
    .admin-sidebar.open{transform:translateX(0)}
    .admin-main{margin-left:0!important}
    #admin-sidebar-toggle{display:flex!important}
}

/* Pkg cards on buy ticket page */
@media(max-width:480px){
    .pkg-card{padding:16px 12px}
}
