/* ============================================
   CrystalDock — Crystal Harbor Command Interface
   ============================================ */

:root{
  --abyss:#071029;
  --deep:#0a1733;
  --hull:#102347;
  --glass:rgba(28,58,110,0.42);
  --glass-line:rgba(120,200,230,0.22);
  --cyan:#4fd6e0;
  --cyan-soft:#8fe7ee;
  --blue:#2a6df4;
  --blue-deep:#1c4fb0;
  --ice:#e8f6fb;
  --mist:#a9c4dd;
  --text:#dceaf5;
  --text-dim:#9db4cc;
  --white:#ffffff;
  --radius:16px;
  --radius-sm:10px;
  --maxw:1160px;
  --shadow:0 18px 48px -18px rgba(2,10,30,0.7);
  --grid-cyan:rgba(79,214,224,0.10);
  --font-display:"Space Grotesk","Segoe UI",system-ui,sans-serif;
  --font-body:"Inter","Segoe UI",system-ui,-apple-system,sans-serif;
}

@import url('https://fonts.googleapis.com/css2?family=Space+Grotesk:wght@400;500;600;700&family=Inter:wght@400;500;600&display=swap');

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
@media (prefers-reduced-motion:reduce){html{scroll-behavior:auto}*{animation:none!important;transition:none!important}}

body{
  font-family:var(--font-body);
  color:var(--text);
  background:
    radial-gradient(1200px 600px at 78% -8%, rgba(42,109,244,0.22), transparent 60%),
    radial-gradient(900px 500px at 5% 18%, rgba(79,214,224,0.12), transparent 55%),
    var(--abyss);
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}

.container{width:100%;max-width:var(--maxw);margin:0 auto;padding:0 24px}
.narrow{max-width:760px}

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

.skip-link{position:absolute;left:-999px;top:0;background:var(--cyan);color:var(--abyss);padding:10px 16px;z-index:200;border-radius:0 0 8px 0}
.skip-link:focus{left:0}

:focus-visible{outline:2px solid var(--cyan);outline-offset:3px;border-radius:4px}

/* ---------- Typography ---------- */
h1,h2,h3,h4{font-family:var(--font-display);line-height:1.12;letter-spacing:-0.02em;color:var(--white);font-weight:600}
h1{font-size:clamp(2.1rem,5.2vw,3.6rem)}
h2{font-size:clamp(1.6rem,3.6vw,2.5rem)}
h3{font-size:1.25rem}
.eyebrow{display:inline-block;font-family:var(--font-display);font-size:0.78rem;font-weight:600;letter-spacing:0.18em;text-transform:uppercase;color:var(--cyan);margin-bottom:14px;padding-left:2px}

/* ---------- Buttons ---------- */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:8px;
  font-family:var(--font-display);font-weight:600;font-size:0.95rem;
  padding:14px 24px;border-radius:var(--radius-sm);border:1px solid transparent;
  cursor:pointer;transition:transform .2s ease, box-shadow .2s ease, background .2s ease;
  text-align:center;
}
.btn-sm{padding:9px 16px;font-size:0.85rem}
.btn-block{width:100%}
.btn-primary{background:linear-gradient(120deg,var(--cyan),var(--blue));color:#04132e;box-shadow:0 10px 28px -10px rgba(42,109,244,0.7)}
.btn-primary:hover{transform:translateY(-2px);color:#04132e;box-shadow:0 16px 34px -10px rgba(79,214,224,0.6)}
.btn-ghost{background:rgba(120,200,230,0.08);color:var(--ice);border-color:var(--glass-line)}
.btn-ghost:hover{background:rgba(120,200,230,0.16);color:var(--white);transform:translateY(-2px)}
.btn-outline{background:transparent;color:var(--cyan-soft);border-color:var(--glass-line)}
.btn-outline:hover{border-color:var(--cyan);color:var(--cyan);transform:translateY(-2px)}

/* ---------- Header ---------- */
.site-header{position:sticky;top:0;z-index:100;backdrop-filter:blur(14px);
  background:linear-gradient(180deg,rgba(7,16,41,0.92),rgba(7,16,41,0.55));
  border-bottom:1px solid var(--glass-line)}
.header-inner{display:flex;align-items:center;justify-content:space-between;height:70px}
.brand{display:flex;align-items:center;gap:10px}
.brand-name{font-family:var(--font-display);font-size:1.25rem;font-weight:500;color:var(--white);letter-spacing:-0.01em}
.brand-name strong{font-weight:700;color:var(--cyan)}
.main-nav{display:flex;align-items:center}
.nav-list{list-style:none;display:flex;gap:6px;align-items:center}
.nav-list a{display:inline-block;padding:9px 14px;border-radius:8px;color:var(--text-dim);font-weight:500;font-size:0.95rem;transition:color .2s,background .2s}
.nav-list a:hover{color:var(--white);background:rgba(120,200,230,0.08)}
.nav-cta{background:linear-gradient(120deg,var(--cyan),var(--blue));color:#04132e!important;font-weight:600}
.nav-cta:hover{transform:translateY(-1px)}
.nav-toggle{display:none;flex-direction:column;gap:5px;background:none;border:0;cursor:pointer;padding:8px}
.nav-toggle span{width:24px;height:2px;background:var(--ice);border-radius:2px;transition:.25s}
.nav-toggle[aria-expanded="true"] span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.nav-toggle[aria-expanded="true"] span:nth-child(2){opacity:0}
.nav-toggle[aria-expanded="true"] span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

/* ---------- Hero ---------- */
.hero{position:relative;padding:72px 0 60px;overflow:hidden}
.hero-grid{position:absolute;inset:0;z-index:0;pointer-events:none;
  background-image:linear-gradient(var(--grid-cyan) 1px,transparent 1px),linear-gradient(90deg,var(--grid-cyan) 1px,transparent 1px);
  background-size:46px 46px;
  mask-image:radial-gradient(900px 500px at 70% 30%,#000 35%,transparent 80%);
  -webkit-mask-image:radial-gradient(900px 500px at 70% 30%,#000 35%,transparent 80%)}
.hero-inner{position:relative;z-index:1;display:grid;grid-template-columns:1.05fr 0.95fr;gap:48px;align-items:center}
.hero-copy .lead{font-size:1.12rem;color:var(--text-dim);max-width:46ch;margin:18px 0 28px}
.hero-actions{display:flex;gap:14px;flex-wrap:wrap}
.hero-stats{display:flex;gap:32px;margin-top:40px;flex-wrap:wrap}
.hero-stats dt{font-family:var(--font-display);font-size:1.7rem;font-weight:700;color:var(--cyan)}
.hero-stats dd{font-size:0.85rem;color:var(--text-dim)}
.hero-panel{position:relative;border-radius:var(--radius);overflow:hidden;border:1px solid var(--glass-line);
  background:var(--glass);box-shadow:var(--shadow);padding:10px}
.hero-panel img{border-radius:12px;width:100%;object-fit:cover;aspect-ratio:3/2}
.panel-tag{position:absolute;left:20px;bottom:20px;background:rgba(7,16,41,0.78);backdrop-filter:blur(8px);
  border:1px solid var(--glass-line);color:var(--cyan-soft);font-size:0.78rem;font-family:var(--font-display);
  padding:8px 14px;border-radius:999px;letter-spacing:0.04em}

/* ---------- Strip ---------- */
.strip{border-top:1px solid var(--glass-line);border-bottom:1px solid var(--glass-line);
  background:rgba(16,35,71,0.4)}
.strip-inner{padding:18px 24px;text-align:center}
.strip p{font-family:var(--font-display);color:var(--mist);letter-spacing:0.04em;font-size:0.95rem}

/* ---------- Sections ---------- */
.section{padding:84px 0}
.section-alt{background:linear-gradient(180deg,rgba(10,23,51,0.5),rgba(7,16,41,0))}
.section-head{max-width:680px;margin-bottom:48px}
.section-head p{color:var(--text-dim);margin-top:14px;font-size:1.05rem}

/* ---------- Cards ---------- */
.card-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.card{position:relative;background:var(--glass);border:1px solid var(--glass-line);border-radius:var(--radius);
  overflow:hidden;backdrop-filter:blur(10px);transition:transform .25s ease,border-color .25s ease;display:flex;flex-direction:column}
.card:hover{transform:translateY(-6px);border-color:rgba(79,214,224,0.5)}
.card img{width:100%;aspect-ratio:3/2;object-fit:cover}
.card-body{padding:24px;display:flex;flex-direction:column;gap:12px;flex:1}
.card-body p{color:var(--text-dim);font-size:0.96rem}
.card-featured{border-color:rgba(79,214,224,0.55);box-shadow:0 20px 50px -22px rgba(79,214,224,0.4)}
.card-badge{position:absolute;top:14px;right:14px;z-index:2;background:linear-gradient(120deg,var(--cyan),var(--blue));
  color:#04132e;font-family:var(--font-display);font-weight:700;font-size:0.72rem;letter-spacing:0.06em;
  padding:6px 12px;border-radius:999px;text-transform:uppercase}
.card-link{font-family:var(--font-display);font-weight:600;color:var(--cyan);margin-top:auto}
.ticks{list-style:none;display:flex;flex-direction:column;gap:8px}
.ticks li{position:relative;padding-left:24px;color:var(--text);font-size:0.92rem}
.ticks li::before{content:"";position:absolute;left:0;top:8px;width:11px;height:11px;border-radius:3px;
  background:linear-gradient(120deg,var(--cyan),var(--blue));box-shadow:0 0 10px rgba(79,214,224,0.6)}

/* ---------- Steps ---------- */
.steps{list-style:none;display:grid;grid-template-columns:repeat(4,1fr);gap:20px;counter-reset:none}
.step{background:var(--glass);border:1px solid var(--glass-line);border-radius:var(--radius);padding:26px 22px;backdrop-filter:blur(8px);position:relative}
.step-num{font-family:var(--font-display);font-size:0.9rem;font-weight:700;color:var(--abyss);
  background:linear-gradient(120deg,var(--cyan),var(--blue));display:inline-flex;align-items:center;justify-content:center;
  width:38px;height:38px;border-radius:10px;margin-bottom:14px;letter-spacing:0.02em}
.step h3{font-size:1.08rem;margin-bottom:8px}
.step p{color:var(--text-dim);font-size:0.92rem}

/* ---------- Prices ---------- */
.price-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;align-items:start}
.price-card{background:var(--glass);border:1px solid var(--glass-line);border-radius:var(--radius);
  padding:30px 26px;backdrop-filter:blur(10px);display:flex;flex-direction:column;gap:16px;position:relative}
.price-highlight{border-color:rgba(79,214,224,0.55);box-shadow:0 22px 54px -22px rgba(42,109,244,0.5);
  background:linear-gradient(180deg,rgba(28,58,110,0.6),rgba(16,35,71,0.4))}
.price{display:flex;align-items:baseline;gap:8px}
.price .amount{font-family:var(--font-display);font-size:2.5rem;font-weight:700;color:var(--white)}
.price .per{color:var(--text-dim);font-size:0.9rem}
.price-note{color:var(--cyan-soft);font-size:0.88rem;margin-top:-8px}
.price-card .ticks{margin:6px 0}
.price-card .btn{margin-top:auto}
.price-legal{margin-top:28px;color:var(--text-dim);font-size:0.88rem;text-align:center;max-width:760px;margin-left:auto;margin-right:auto}

/* ---------- Band ---------- */
.band{padding:0 0 84px}
.band-inner{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:center;
  background:var(--glass);border:1px solid var(--glass-line);border-radius:24px;overflow:hidden;backdrop-filter:blur(10px)}
.band-copy{padding:48px}
.band-copy p{color:var(--text-dim);margin:14px 0 24px}
.band-media{height:100%}
.band-media img{width:100%;height:100%;object-fit:cover;min-height:320px}

/* ---------- FAQ ---------- */
.faq{display:flex;flex-direction:column;gap:12px}
.faq details{background:var(--glass);border:1px solid var(--glass-line);border-radius:var(--radius-sm);padding:4px 20px;backdrop-filter:blur(8px)}
.faq summary{cursor:pointer;font-family:var(--font-display);font-weight:600;color:var(--white);padding:16px 0;list-style:none;display:flex;justify-content:space-between;align-items:center;gap:16px}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:"+";font-size:1.5rem;color:var(--cyan);font-weight:400;transition:transform .2s}
.faq details[open] summary::after{transform:rotate(45deg)}
.faq details p{color:var(--text-dim);padding:0 0 18px;font-size:0.96rem}

/* ---------- Contact ---------- */
.contact-grid{display:grid;grid-template-columns:0.9fr 1.1fr;gap:48px;align-items:start}
.contact-info p{color:var(--text-dim);margin:14px 0 24px}
.contact-list{list-style:none;display:flex;flex-direction:column;gap:16px}
.contact-list li{display:flex;flex-direction:column;gap:2px}
.contact-list strong{font-family:var(--font-display);font-size:0.78rem;letter-spacing:0.12em;text-transform:uppercase;color:var(--cyan)}
.contact-list a,.contact-list span{color:var(--text)}
.contact-form{background:var(--glass);border:1px solid var(--glass-line);border-radius:var(--radius);padding:30px;backdrop-filter:blur(10px);display:flex;flex-direction:column;gap:18px}
.field{display:flex;flex-direction:column;gap:6px}
.field label{font-family:var(--font-display);font-size:0.85rem;font-weight:500;color:var(--ice)}
.field input,.field select,.field textarea{
  background:rgba(7,16,41,0.6);border:1px solid var(--glass-line);border-radius:10px;
  padding:12px 14px;color:var(--white);font-family:var(--font-body);font-size:0.96rem;transition:border-color .2s}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--cyan)}
.field textarea{resize:vertical}
.field select{appearance:none;background-image:linear-gradient(45deg,transparent 50%,var(--cyan) 50%),linear-gradient(135deg,var(--cyan) 50%,transparent 50%);background-position:calc(100% - 20px) center,calc(100% - 14px) center;background-size:6px 6px,6px 6px;background-repeat:no-repeat}
.error{color:#ff9aa6;font-size:0.8rem;min-height:0}
.check{display:flex;gap:10px;align-items:flex-start;font-size:0.88rem;color:var(--text-dim)}
.check input{margin-top:3px;accent-color:var(--cyan);width:16px;height:16px;flex-shrink:0}
.form-status{font-size:0.9rem;min-height:1em}
.form-status.ok{color:var(--cyan)}
.form-status.err{color:#ff9aa6}

/* ---------- Footer ---------- */
.site-footer{border-top:1px solid var(--glass-line);background:rgba(7,16,41,0.6);padding:56px 0 0;margin-top:20px}
.footer-inner{display:grid;grid-template-columns:1.6fr 1fr 1fr 1fr;gap:32px}
.footer-brand p{color:var(--text-dim);font-size:0.9rem;margin-top:12px;max-width:34ch}
.footer-legal-name{font-size:0.8rem!important;color:var(--mist)!important;margin-top:14px!important}
.footer-col h4{font-family:var(--font-display);font-size:0.82rem;letter-spacing:0.12em;text-transform:uppercase;color:var(--cyan);margin-bottom:14px}
.footer-col ul{list-style:none;display:flex;flex-direction:column;gap:9px}
.footer-col a{color:var(--text-dim);font-size:0.92rem}
.footer-col a:hover{color:var(--white)}
.footer-col li{color:var(--text-dim);font-size:0.92rem}
.footer-bottom{border-top:1px solid var(--glass-line);margin-top:40px;padding:22px 24px;text-align:center}
.footer-bottom p{color:var(--mist);font-size:0.85rem}

/* ---------- Cookie banner ---------- */
.cookie-banner{position:fixed;left:20px;right:20px;bottom:20px;z-index:150;max-width:920px;margin:0 auto;
  background:linear-gradient(180deg,rgba(16,35,71,0.96),rgba(10,23,51,0.96));backdrop-filter:blur(16px);
  border:1px solid var(--glass-line);border-radius:var(--radius);box-shadow:var(--shadow);
  padding:20px 24px;display:flex;gap:20px;align-items:center;flex-wrap:wrap;justify-content:space-between}
.cookie-text p{color:var(--text);font-size:0.92rem;max-width:60ch}
.cookie-actions{display:flex;gap:10px;flex-shrink:0}

/* ---------- Legal pages ---------- */
.legal-main{padding:60px 0 80px;max-width:840px;margin:0 auto}
.legal-main h1{margin-bottom:8px}
.legal-updated{color:var(--text-dim);font-size:0.9rem;margin-bottom:36px}
.legal-main h2{font-size:1.4rem;margin:34px 0 12px}
.legal-main h3{font-size:1.1rem;margin:22px 0 8px}
.legal-main p,.legal-main li{color:var(--text-dim);margin-bottom:12px}
.legal-main ul,.legal-main ol{padding-left:22px;margin-bottom:12px}
.legal-main li{margin-bottom:6px}
.legal-main a{color:var(--cyan-soft)}
.back-home{display:inline-flex;gap:8px;align-items:center;margin-bottom:30px;font-family:var(--font-display);font-weight:600;color:var(--cyan)}

/* ---------- Responsive ---------- */
@media (max-width:960px){
  .hero-inner{grid-template-columns:1fr;gap:36px}
  .card-grid,.price-grid{grid-template-columns:1fr 1fr}
  .steps{grid-template-columns:1fr 1fr}
  .band-inner{grid-template-columns:1fr}
  .band-media img{min-height:240px}
  .contact-grid{grid-template-columns:1fr}
  .footer-inner{grid-template-columns:1fr 1fr}
}
@media (max-width:680px){
  .nav-toggle{display:flex}
  .nav-list{position:absolute;top:70px;left:0;right:0;flex-direction:column;align-items:stretch;gap:0;
    background:rgba(7,16,41,0.98);backdrop-filter:blur(16px);border-bottom:1px solid var(--glass-line);
    padding:8px 16px 16px;transform:translateY(-130%);transition:transform .3s ease;visibility:hidden}
  .nav-list.open{transform:translateY(0);visibility:visible}
  .nav-list a{padding:14px 8px;border-radius:8px}
  .nav-cta{text-align:center;margin-top:6px}
  .section{padding:60px 0}
  .card-grid,.price-grid,.steps,.footer-inner{grid-template-columns:1fr}
  .hero-stats{gap:24px}
  .band-copy{padding:32px 26px}
  .cookie-banner{flex-direction:column;align-items:stretch;text-align:left}
  .cookie-actions{justify-content:stretch}
  .cookie-actions .btn{flex:1}
}
