/*
Theme Name: Alfa Marine Refined v8
Theme URI: https://example.com/
Author: OpenAI
Description: Custom luxury marine WordPress theme for Alfa Marine Greece.
Version: 8.0
Requires at least: 6.0
Tested up to: 6.5
Requires PHP: 7.4
Text Domain: alfa-marine-refined
*/

:root{
  --bg:#f6f3ee;
  --surface:#ffffff;
  --ink:#0f1c2f;
  --muted:#5d6674;
  --gold:#c7a56a;
  --gold-deep:#a88449;
  --line:rgba(15,28,47,.12);
  --navy:#10233f;
  --navy-soft:#183154;
  --shadow:0 20px 60px rgba(16,35,63,.12);
  --radius:22px;
  --radius-sm:14px;
  --container:min(1180px, calc(100vw - 40px));
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;font-family:Inter,system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif;background:var(--bg);color:var(--ink);line-height:1.6}
a{color:inherit;text-decoration:none}
img,video{max-width:100%;display:block}
.container{width:var(--container);margin:0 auto}
.site-header{position:sticky;top:0;z-index:1000;background:rgba(246,243,238,.88);backdrop-filter:blur(18px);border-bottom:1px solid var(--line)}
.header-inner{display:flex;align-items:center;justify-content:space-between;gap:20px;min-height:82px}
.branding a{font-weight:700;letter-spacing:.08em;text-transform:uppercase}
.branding small{display:block;color:var(--muted);font-size:12px;letter-spacing:.08em;text-transform:uppercase}
.main-navigation ul{list-style:none;margin:0;padding:0;display:flex;gap:28px;align-items:center}
.main-navigation li{position:relative}
.main-navigation .sub-menu{display:none;position:absolute;top:100%;left:0;min-width:220px;background:#fff;padding:14px;border:1px solid var(--line);border-radius:16px;box-shadow:var(--shadow)}
.main-navigation li:hover>.sub-menu{display:block}
.main-navigation .sub-menu li{margin:0 0 8px}
.main-navigation .sub-menu li:last-child{margin-bottom:0}
.header-cta{display:flex;align-items:center;gap:12px}
.btn{display:inline-flex;align-items:center;justify-content:center;padding:14px 22px;border-radius:999px;border:1px solid transparent;font-weight:600;transition:.25s ease}
.btn-primary{background:linear-gradient(135deg,var(--gold),var(--gold-deep));color:#fff;box-shadow:0 12px 24px rgba(167,132,73,.2)}
.btn-primary:hover{transform:translateY(-1px);filter:brightness(1.03)}
.btn-secondary{background:transparent;border-color:rgba(255,255,255,.35);color:#fff}
.btn-outline{border-color:var(--line);background:#fff}
.mobile-toggle{display:none;background:none;border:none;font-size:26px}
.hero{position:relative;color:#fff;background:linear-gradient(180deg, rgba(8,17,31,.45), rgba(8,17,31,.72)), radial-gradient(circle at top right, rgba(199,165,106,.16), transparent 30%), var(--navy);min-height:78vh;display:flex;align-items:flex-end;overflow:hidden}
.hero-media,.page-hero-media{position:absolute;inset:0;z-index:0}
.hero-media img,.hero-media video,.page-hero-media img,.page-hero-media video{width:100%;height:100%;object-fit:cover}
.hero::after,.page-hero::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg, rgba(7,16,28,.18), rgba(7,16,28,.72))}
.hero-content,.page-hero-content{position:relative;z-index:1;padding:120px 0 72px}
.eyebrow{display:inline-block;padding:8px 12px;border:1px solid rgba(255,255,255,.24);border-radius:999px;text-transform:uppercase;letter-spacing:.14em;font-size:12px;margin-bottom:18px;background:rgba(255,255,255,.06)}
.hero h1,.page-hero h1{font-size:clamp(42px,7vw,74px);line-height:.98;letter-spacing:-.04em;margin:0 0 18px;max-width:9ch}
.hero p,.page-hero p{max-width:640px;font-size:18px;color:rgba(255,255,255,.9);margin:0 0 28px}
.hero-actions{display:flex;flex-wrap:wrap;gap:14px;margin-bottom:38px}
.hero-stats{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:16px;max-width:760px}
.stat-card{background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.12);backdrop-filter:blur(10px);border-radius:18px;padding:18px 20px}
.stat-card strong{display:block;font-size:28px;line-height:1.1;margin-bottom:4px}
.section{padding:88px 0}
.section-dark{background:var(--navy);color:#fff}
.section-header{display:grid;grid-template-columns:1.1fr .9fr;gap:36px;align-items:end;margin-bottom:34px}
.section-header h2{font-size:clamp(32px,4vw,54px);line-height:1.05;margin:0;letter-spacing:-.03em}
.section-header p{margin:0;color:var(--muted);font-size:17px}
.section-dark .section-header p{color:rgba(255,255,255,.72)}
.grid{display:grid;gap:24px}
.grid-2{grid-template-columns:repeat(2,minmax(0,1fr))}
.grid-3{grid-template-columns:repeat(3,minmax(0,1fr))}
.card{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:28px;box-shadow:var(--shadow)}
.section-dark .card{background:rgba(255,255,255,.06);border-color:rgba(255,255,255,.1);box-shadow:none}
.card h3{margin:0 0 10px;font-size:24px;letter-spacing:-.02em}
.card p{margin:0;color:var(--muted)}
.section-dark .card p{color:rgba(255,255,255,.75)}
.feature-list{display:grid;gap:12px;padding:0;margin:0;list-style:none}
.feature-list li{position:relative;padding-left:22px}
.feature-list li::before{content:"";position:absolute;left:0;top:.7em;width:9px;height:9px;border-radius:999px;background:linear-gradient(135deg,var(--gold),var(--gold-deep))}
.split-media{display:grid;grid-template-columns:1.05fr .95fr;gap:30px;align-items:stretch}
.media-panel{position:relative;border-radius:32px;overflow:hidden;min-height:540px;background:linear-gradient(180deg,#203658,#10233f)}
.media-panel .placeholder{position:absolute;inset:0;display:grid;place-items:center;color:rgba(255,255,255,.8);text-align:center;padding:30px;background:linear-gradient(180deg, rgba(7,16,28,.28), rgba(7,16,28,.72))}
.media-panel .placeholder span{display:block;font-size:13px;letter-spacing:.12em;text-transform:uppercase;color:rgba(255,255,255,.62);margin-bottom:10px}
.media-panel img,.media-panel video{width:100%;height:100%;object-fit:cover}
.panel-stack{display:grid;gap:24px}
.kicker{color:var(--gold);text-transform:uppercase;letter-spacing:.12em;font-weight:700;font-size:12px;margin-bottom:12px}
.lead{font-size:18px;color:var(--muted)}
.service-columns{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:24px;margin-top:28px}
.numbered{counter-reset:item;display:grid;gap:16px;padding:0;list-style:none}
.numbered li{counter-increment:item;background:#fff;border:1px solid var(--line);border-radius:18px;padding:20px 20px 20px 74px;position:relative;box-shadow:var(--shadow)}
.numbered li::before{content:counter(item, decimal-leading-zero);position:absolute;left:18px;top:18px;width:40px;height:40px;border-radius:50%;display:grid;place-items:center;background:var(--navy);color:#fff;font-weight:700}
.gallery-strip{display:grid;grid-template-columns:1.3fr .7fr .7fr;gap:18px;margin-top:28px}
.gallery-tile{min-height:220px;border-radius:24px;overflow:hidden;background:linear-gradient(180deg,#d8d0c2,#9caab9);position:relative}
.gallery-tile .overlay{position:absolute;inset:auto 0 0 0;padding:18px;background:linear-gradient(180deg,transparent,rgba(16,35,63,.8));color:#fff}
.cta-band{background:linear-gradient(135deg,var(--navy),var(--navy-soft));color:#fff;border-radius:34px;padding:38px;display:grid;grid-template-columns:1fr auto;gap:20px;align-items:center;box-shadow:var(--shadow)}
.cta-band p{margin:8px 0 0;color:rgba(255,255,255,.78)}
.site-footer{background:#0c1729;color:#fff;padding:34px 0 18px}
.footer-grid{display:grid;grid-template-columns:1.2fr .8fr .8fr;gap:24px;padding-bottom:20px}
.site-footer p,.site-footer li{color:rgba(255,255,255,.7)}
.site-footer ul{padding:0;list-style:none;margin:0;display:grid;gap:10px}
.site-footer h4{margin:0 0 12px}
.footer-bottom{border-top:1px solid rgba(255,255,255,.12);padding-top:14px;color:rgba(255,255,255,.6);font-size:14px}
.page-hero{position:relative;color:#fff;min-height:72vh;display:flex;align-items:flex-end;background:var(--navy);overflow:hidden}
.highlight-band{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:18px;margin-top:-48px;position:relative;z-index:2}
.highlight{background:#fff;border:1px solid var(--line);border-radius:22px;padding:22px;box-shadow:var(--shadow)}
.highlight strong{display:block;font-size:15px;text-transform:uppercase;letter-spacing:.1em;color:var(--muted);margin-bottom:10px}
.highlight span{font-size:22px;line-height:1.2;font-weight:700}
.content-block{padding:72px 0}
.center{text-align:center}
.muted{color:var(--muted)}
@media (max-width: 980px){
  .mobile-toggle{display:block}
  .main-navigation{display:none;position:absolute;left:20px;right:20px;top:76px;background:#fff;border:1px solid var(--line);border-radius:20px;padding:16px;box-shadow:var(--shadow)}
  .main-navigation.open{display:block}
  .main-navigation ul{flex-direction:column;align-items:flex-start;gap:14px}
  .main-navigation .sub-menu{position:static;display:block;border:none;box-shadow:none;padding:8px 0 0 12px}
  .header-cta .btn{display:none}
  .section-header,.split-media,.service-columns,.footer-grid,.gallery-strip,.cta-band,.highlight-band,.grid-2,.grid-3,.hero-stats{grid-template-columns:1fr}
  .media-panel{min-height:360px}
  .hero-content,.page-hero-content{padding:110px 0 44px}
  .hero h1,.page-hero h1{max-width:none}
}


.branding-link{display:flex;align-items:center;min-height:48px}
.branding .custom-logo{max-height:56px;width:auto;display:block}
.branding .brand-text{font-weight:700;letter-spacing:.08em;text-transform:uppercase}
.main-navigation ul ul{margin-top:8px}


/* Header fixes v8 */
.site-header{position:sticky;top:0;z-index:1000;width:100%;}
.header-inner{flex-wrap:nowrap;position:relative;}
.branding{display:flex;flex-direction:column;justify-content:center;gap:4px;min-width:0;max-width:280px;flex:0 0 auto;}
.branding-logo,.branding-link{display:flex;align-items:center;min-height:48px;max-width:100%;}
.custom-logo-link{display:inline-flex !important;align-items:center;line-height:1;}
.branding .custom-logo,.custom-logo{max-height:44px !important;width:auto !important;height:auto !important;max-width:220px;object-fit:contain;}
.branding small{margin-top:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.main-navigation{flex:1 1 auto;min-width:0;}
.main-navigation > div > ul,
.main-navigation > ul{justify-content:center;flex-wrap:wrap;row-gap:10px;}
.main-navigation a{display:inline-block;padding:6px 0;}
.site-header + *{position:relative;z-index:1;}

@media (max-width: 980px){
  .site-header{position:sticky;}
  .header-inner{min-height:74px;}
  .branding{max-width:170px;}
  .branding .custom-logo,.custom-logo{max-height:36px !important;max-width:160px;}
  .branding small{font-size:10px;white-space:normal;line-height:1.2;}
  .main-navigation{display:none;position:absolute;left:0;right:0;top:100%;margin-top:10px;background:#fff;border:1px solid var(--line);border-radius:20px;padding:16px;box-shadow:var(--shadow);}
  .main-navigation.open{display:block;}
  .main-navigation > div > ul,
  .main-navigation > ul{justify-content:flex-start;flex-wrap:nowrap;}
}

.gallery-tile img,.gallery-tile video{width:100%;height:100%;object-fit:cover;display:block;}
.gallery-tile .overlay-placeholder{position:absolute;inset:0;display:grid;place-items:center;text-align:center;padding:24px;color:rgba(255,255,255,.8);background:linear-gradient(180deg, rgba(7,16,28,.28), rgba(7,16,28,.5));}

.section-dark .numbered li{color:var(--ink);}
.section-dark .numbered li strong{color:var(--ink);}


.charter-two-up{grid-template-columns:repeat(2,minmax(0,1fr));}
.charter-option-grid .btn{margin-top:18px;}
@media (max-width: 980px){
  .charter-two-up{grid-template-columns:1fr;}
}

.footer-social{display:flex;gap:12px;margin-top:16px;align-items:center}
.social-link{width:40px;height:40px;border:1px solid rgba(255,255,255,.18);border-radius:999px;display:inline-flex;align-items:center;justify-content:center;color:#fff;transition:transform .2s ease,border-color .2s ease,background .2s ease}
.social-link:hover{transform:translateY(-1px);border-color:rgba(255,255,255,.35);background:rgba(255,255,255,.08)}
.social-link svg{width:18px;height:18px;display:block}


/* Final polish updates */
.site-header{
  background:rgba(246,243,238,.58);
  border-bottom:1px solid rgba(255,255,255,.12);
  transform:translateY(0);
  transition:background .28s ease, box-shadow .28s ease, transform .28s ease, border-color .28s ease;
}
.site-header.is-scrolled{
  background:rgba(246,243,238,.9);
  box-shadow:0 14px 40px rgba(16,35,63,.12);
  border-bottom-color:rgba(15,28,47,.08);
}
.site-header.is-hidden{transform:translateY(-100%)}
.main-navigation a{
  border-radius:999px;
  padding:10px 14px;
  transition:background .22s ease, box-shadow .22s ease, color .22s ease, transform .22s ease;
}
.main-navigation li:hover > a,
.main-navigation li.current-menu-item > a,
.main-navigation li.current_page_item > a{
  background:rgba(16,35,63,.08);
  box-shadow:0 10px 24px rgba(16,35,63,.08);
  transform:translateY(-1px);
}
.main-navigation .sub-menu{
  padding:12px;
  background:rgba(255,255,255,.96);
  backdrop-filter:blur(14px);
}
.main-navigation .sub-menu a{display:block;padding:10px 12px;border-radius:12px}
.main-navigation .sub-menu li:hover > a{
  background:rgba(16,35,63,.08);
  box-shadow:0 8px 18px rgba(16,35,63,.08);
}
.alfa-slideshow{position:relative;width:100%;height:100%;min-height:inherit;background:#132743;overflow:hidden}
.alfa-slide{position:absolute;inset:0;opacity:0;transition:opacity .6s ease}
.alfa-slide.is-active{opacity:1}
.alfa-slide img{width:100%;height:100%;object-fit:cover;display:block}
.alfa-video-media{width:100%;height:100%;object-fit:cover;display:block;background:#132743}
.alfa-slideshow-dots{position:absolute;left:18px;bottom:16px;display:flex;gap:8px;z-index:2}
.alfa-dot{width:9px;height:9px;border-radius:999px;background:rgba(255,255,255,.4);box-shadow:0 4px 10px rgba(0,0,0,.18);cursor:pointer}
.alfa-dot.is-active{background:#fff}
.contact-highlights{grid-template-columns:repeat(4,minmax(0,1fr))}
.contact-split{align-items:start}
.contact-form-card,.map-card{background:#fff}
.contact-highlights .highlight{min-width:0}
.contact-highlights .highlight span{display:block;min-width:0;max-width:100%;font-size:clamp(18px,2vw,22px);line-height:1.22;overflow-wrap:anywhere;word-break:break-word}
.contact-highlights .highlight .contact-email-fit{font-size:clamp(16px,1.55vw,18px);line-height:1.35;letter-spacing:-.01em;overflow-wrap:normal;word-break:normal;hyphens:none}
.contact-form-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:16px}
.contact-form-grid label{display:grid;gap:8px;font-size:14px;font-weight:600;color:var(--ink)}
.contact-form-grid .full{grid-column:1/-1}
.contact-form-grid input,.contact-form-grid textarea,.contact-form-grid select{
  width:100%;padding:14px 16px;border-radius:16px;border:1px solid var(--line);background:#fbfaf8;color:var(--ink);font:inherit;
}
.contact-form-grid input:focus,.contact-form-grid textarea:focus,.contact-form-grid select:focus{outline:none;border-color:rgba(199,165,106,.8);box-shadow:0 0 0 4px rgba(199,165,106,.12)}
.contact-notice{padding:14px 16px;border-radius:16px;margin-bottom:18px;font-weight:600}
.contact-notice.success{background:rgba(87,167,124,.12);color:#245d3d}
.contact-notice.error{background:rgba(180,75,75,.12);color:#7e2525}
.contact-map-embed iframe{width:100%;border:0;border-radius:20px;min-height:380px}
.contact-admin-hint{font-size:13px;color:var(--muted);margin:0}
@media (max-width:980px){
  .contact-highlights{grid-template-columns:1fr}
  .contact-form-grid{grid-template-columns:1fr}
}


/* Refinement pass: header, contact, cross-links */
.site-header{
  background:rgba(246,243,238,.34);
  backdrop-filter:saturate(150%) blur(10px);
}
.site-header.is-scrolled{
  background:rgba(246,243,238,.92);
  box-shadow:0 18px 42px rgba(16,35,63,.14);
}
.header-inner{min-height:84px}
.main-navigation li{position:relative}
.main-navigation > div > ul > li > a,
.main-navigation > ul > li > a{font-weight:600;letter-spacing:.01em}
.main-navigation li:hover > a,
.main-navigation li.current-menu-item > a,
.main-navigation li.current_page_item > a{
  background:rgba(255,255,255,.72);
  box-shadow:0 10px 24px rgba(16,35,63,.12);
}
.main-navigation .sub-menu{border:1px solid rgba(16,35,63,.08);border-radius:18px}
.main-navigation .sub-menu li + li{margin-top:4px}
.main-navigation .sub-menu li:hover > a{background:rgba(199,165,106,.14)}
.contact-overview{padding:26px 0 0}
.contact-overview-card{display:flex;justify-content:space-between;gap:24px;align-items:center;background:linear-gradient(135deg, rgba(255,255,255,.94), rgba(246,243,238,.92));border:1px solid var(--line);border-radius:28px;padding:28px 30px;box-shadow:var(--shadow)}
.contact-layout .panel-stack{gap:20px}
.map-card,.contact-form-card{border:1px solid var(--line);box-shadow:var(--shadow)}
.contact-form-card{padding:26px}
.map-card{padding:26px}
.contact-map-embed{margin-top:16px}
.dual-cta-actions{display:flex;gap:12px;flex-wrap:wrap;justify-content:flex-end}
@media (max-width:980px){
  .contact-overview-card{display:grid}
  .dual-cta-actions{justify-content:flex-start}
}


/* Small fixes: header CTA + contact highlight overlap */
.header-cta{flex:0 0 auto}
.header-cta .btn{
  white-space:nowrap;
  min-width:0;
  padding:14px 26px;
  line-height:1.1;
}
@media (max-width:1180px){
  .header-inner{gap:14px}
  .main-navigation > div > ul,
  .main-navigation > ul{gap:12px}
  .main-navigation a{padding:9px 12px}
  .header-cta .btn{padding:13px 20px;font-size:15px}
}
.contact-highlights{
  margin-top:22px;
  position:relative;
  z-index:1;
}
.contact-overview-card{position:relative;z-index:2;overflow:hidden}
.contact-overview .lead{position:relative;z-index:2}
.contact-overview .btn{position:relative;z-index:2}

/* Contact request button visibility fix */
.contact-overview .btn-secondary{
  background:linear-gradient(135deg,var(--navy),var(--navy-soft));
  color:#fff;
  border-color:transparent;
  box-shadow:0 12px 24px rgba(16,35,63,.18);
}
.contact-overview .btn-secondary:hover{
  transform:translateY(-1px);
  filter:brightness(1.03);
}


/* Contact layout stability patch */
.contact-request-panel{min-width:0}
.contact-visual-panel{min-width:0}
.contact-main-media{min-height:360px}
.contact-main-media .placeholder{display:none}
.contact-map-embed:empty{display:none}
.contact-map-embed iframe{display:block;width:100%;min-height:420px;border:0;border-radius:20px}
@media (min-width: 981px){
  .contact-split{grid-template-columns:minmax(320px,.72fr) minmax(0,1.28fr);align-items:start}
}
@media (max-width: 980px){
  .contact-main-media{min-height:260px}
}
