/* Harbor Holdings IP — styles
   Clean, established corporate look with maritime + Wyoming cues.
*/

:root{
  --bg: #070B14;
  --panel: rgba(255,255,255,0.06);
  --panel-2: rgba(255,255,255,0.085);
  --text: rgba(255,255,255,0.92);
  --muted: rgba(255,255,255,0.72);
  --faint: rgba(255,255,255,0.55);
  --line: rgba(255,255,255,0.12);
  --shadow: 0 18px 60px rgba(0,0,0,0.38);
  --shadow-soft: 0 12px 36px rgba(0,0,0,0.28);
  --accent: #7FE7D6;       /* sea glass */
  --accent2: #C8A96A;      /* brass */
  --max: 1160px;

  --radius: 20px;
  --radius-sm: 14px;

  --display: "Fraunces", ui-serif, Georgia, serif;
  --body: "Inter", ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, Helvetica, Arial, "Apple Color Emoji","Segoe UI Emoji";
}

*{box-sizing:border-box}
html, body{height:100%}
body{
  margin:0;
  font-family:var(--body);
  color:var(--text);
  background:
    radial-gradient(1200px 600px at 20% 0%, rgba(127,231,214,0.18), transparent 60%),
    radial-gradient(900px 500px at 85% 15%, rgba(200,169,106,0.14), transparent 55%),
    linear-gradient(180deg, #070B14 0%, #050812 50%, #060A12 100%);
  overflow-x:hidden;
}

a{color:inherit; text-decoration:none}
img{max-width:100%; display:block}
button{font:inherit}

.container{
  width:min(var(--max), calc(100% - 40px));
  margin-inline:auto;
}

.skip-link{
  position:absolute; left:-999px; top:10px;
  background:#fff; color:#000; padding:10px 12px; border-radius:10px;
}
.skip-link:focus{left:10px; z-index:9999}

/* Header */
.header{
  position:fixed; inset:0 0 auto 0;
  z-index:50;
  padding:16px 0;
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  background: rgba(7,11,20,0.48);
  border-bottom: 1px solid rgba(255,255,255,0.08);
}
.header-inner{
  display:flex; align-items:center; justify-content:space-between;
  gap:18px;
}
.brand{
  display:flex; align-items:center; gap:12px;
  min-width: 240px;
}
.brand-mark{
  width:38px; height:38px;
}
.brand-name{
  display:flex; flex-direction:column; line-height:1.05;
}
.brand-name strong{
  font-family:"Space Grotesk", var(--display);
  letter-spacing:0.2px;
  font-size:18px;
}
.brand-name span{
  color:var(--faint);
  font-size:12px;
  letter-spacing:0.18em;
  text-transform:uppercase;
}

/* Nav */
.nav{
  display:flex; align-items:center; gap:18px;
}
.nav a{
  color:var(--muted);
  font-size:13px;
  letter-spacing:0.08em;
  text-transform:uppercase;
  padding:10px 10px;
  border-radius:999px;
  transition: background .2s ease, color .2s ease;
}
.nav a:hover{color:var(--text); background:rgba(255,255,255,0.06)}
.nav a.active{color:var(--text); background:rgba(127,231,214,0.10); outline:1px solid rgba(127,231,214,0.18)}

.header-cta{
  display:flex; align-items:center; gap:10px;
}
.btn{
  display:inline-flex; align-items:center; justify-content:center;
  gap:10px;
  border-radius:999px;
  border:1px solid rgba(255,255,255,0.14);
  padding:11px 14px;
  color:var(--text);
  background:rgba(255,255,255,0.06);
  box-shadow: 0 1px 0 rgba(255,255,255,0.08) inset;
  transition: transform .2s ease, background .2s ease, border-color .2s ease;
  cursor:pointer;
}
.btn:hover{transform: translateY(-1px); background:rgba(255,255,255,0.09); border-color:rgba(255,255,255,0.22)}
.btn.primary{
  border-color: rgba(127,231,214,0.32);
  background: linear-gradient(135deg, rgba(127,231,214,0.18), rgba(200,169,106,0.14));
}
.btn.primary:hover{border-color: rgba(127,231,214,0.42)}
.btn.small{padding:9px 12px; font-size:13px}
.badge{
  display:inline-flex; align-items:center; gap:8px;
  padding:8px 10px;
  border-radius:999px;
  background:rgba(255,255,255,0.06);
  border:1px solid rgba(255,255,255,0.12);
  color:var(--muted);
  font-size:12px;
  letter-spacing:0.08em;
  text-transform:uppercase;
}

/* Mobile nav */
.menu-btn{
  display:none;
  width:42px; height:42px;
  border-radius:12px;
  border:1px solid rgba(255,255,255,0.14);
  background:rgba(255,255,255,0.06);
  cursor:pointer;
}
.menu-btn svg{width:20px; height:20px; margin:auto; display:block}
.mobile-panel{
  display:none;
  position:absolute; right:20px; top:70px;
  width:min(360px, calc(100vw - 40px));
  background:rgba(11,16,32,0.92);
  border:1px solid rgba(255,255,255,0.12);
  border-radius:18px;
  box-shadow: var(--shadow);
  padding:12px;
}
.mobile-panel a{
  display:block;
  padding:12px 12px;
  border-radius:14px;
  color:var(--muted);
}
.mobile-panel a:hover{background:rgba(255,255,255,0.06); color:var(--text)}
.mobile-panel .divider{height:1px; background:rgba(255,255,255,0.10); margin:10px 0}

/* Hero */
.hero{
  position:relative;
  min-height: 96vh;
  display:grid;
  align-items:center;
  padding-top:110px;
  padding-bottom: 60px;
}
.hero::before{
  content:"";
  position:absolute; inset:0;
  background:
    linear-gradient(120deg, rgba(7,11,20,0.70) 0%, rgba(7,11,20,0.40) 45%, rgba(7,11,20,0.78) 100%),
    url("../images/wyoming-hero.jpg") center/cover no-repeat;
  filter: saturate(0.98) contrast(1.02);
  z-index:-2;
}
.hero::after{
  content:"";
  position:absolute; inset:0;
  background:
    radial-gradient(800px 440px at 22% 25%, rgba(127,231,214,0.16), transparent 60%),
    radial-gradient(900px 520px at 72% 35%, rgba(200,169,106,0.14), transparent 60%),
    linear-gradient(180deg, rgba(7,11,20,0.15), rgba(7,11,20,0.70));
  z-index:-1;
}

.hero-grid{
  display:grid;
  grid-template-columns: 1.25fr 0.75fr;
  gap: 26px;
  align-items:end;
}

.kicker{
  display:flex; flex-wrap:wrap; gap:10px;
  margin-bottom:16px;
}
.h1{
  font-family:var(--display);
  font-size: clamp(38px, 4.6vw, 62px);
  line-height:1.02;
  letter-spacing:-0.02em;
  margin:0 0 14px;
}
.lede{
  color:var(--muted);
  max-width: 56ch;
  font-size: 16.5px;
  line-height:1.6;
  margin:0 0 20px;
}
.hero-actions{
  display:flex;
  gap:12px;
  flex-wrap:wrap;
  align-items:center;
  margin-top:18px;
}

.hero-card{
  background: rgba(255,255,255,0.06);
  border: 1px solid rgba(255,255,255,0.12);
  border-radius: var(--radius);
  padding: 18px;
  box-shadow: var(--shadow-soft);
}
.hero-card h3{
  margin:0 0 8px;
  font-size:14px;
  letter-spacing:0.12em;
  text-transform:uppercase;
  color:rgba(255,255,255,0.82);
}
.hero-card p{
  margin:0 0 12px;
  color:var(--muted);
  line-height:1.55;
  font-size:14px;
}
.stats{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:10px;
  margin-top: 14px;
}
.stat{
  background: rgba(255,255,255,0.05);
  border: 1px solid rgba(255,255,255,0.10);
  border-radius: 14px;
  padding:12px;
}
.stat strong{
  display:block;
  font-family:var(--display);
  font-size:20px;
}
.stat span{
  color:var(--faint);
  font-size:12px;
  letter-spacing:0.12em;
  text-transform:uppercase;
}

/* Sections */
.section{
  padding: 88px 0;
  position:relative;
}
.section .section-head{
  display:flex;
  align-items:flex-end;
  justify-content:space-between;
  gap:18px;
  margin-bottom: 28px;
}
.section h2{
  font-family:var(--display);
  font-size: clamp(26px, 2.7vw, 40px);
  margin:0;
  letter-spacing:-0.015em;
}
.section p.sub{
  margin:0;
  color:var(--muted);
  max-width: 64ch;
  line-height:1.6;
  font-size: 15px;
}
.grid-2{
  display:grid;
  grid-template-columns: 1fr 1fr;
  gap: 22px;
}
.card{
  background: var(--panel);
  border: 1px solid var(--line);
  border-radius: var(--radius);
  padding: 20px;
  box-shadow: var(--shadow-soft);
}
.card.soft{background: rgba(255,255,255,0.05)}
.card h3{
  margin:0 0 10px;
  font-size:16px;
  letter-spacing:0.10em;
  text-transform:uppercase;
  color: rgba(255,255,255,0.86);
}
.card p{margin:0; color:var(--muted); line-height:1.65}
.list{
  margin: 14px 0 0; padding:0; list-style:none;
}
.list li{
  display:flex; gap:10px;
  padding:10px 0;
  border-top:1px solid rgba(255,255,255,0.10);
  color: var(--muted);
  line-height:1.6;
}
.list li:first-child{border-top:none; padding-top:0}
.dot{
  width:10px; height:10px; border-radius:999px;
  background: linear-gradient(135deg, var(--accent), var(--accent2));
  margin-top: 6px;
  flex: 0 0 auto;
  box-shadow: 0 0 0 3px rgba(127,231,214,0.08);
}

/* Portfolio cards */
.cards{
  display:grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 16px;
}
.pcard{
  padding: 18px;
  border-radius: var(--radius);
  border: 1px solid rgba(255,255,255,0.12);
  background: rgba(255,255,255,0.06);
  transition: transform .22s ease, background .22s ease, border-color .22s ease;
  overflow:hidden;
  position:relative;
}
.pcard::before{
  content:"";
  position:absolute; inset:-1px;
  background: radial-gradient(450px 220px at 20% 10%, rgba(127,231,214,0.18), transparent 55%),
              radial-gradient(420px 220px at 85% 20%, rgba(200,169,106,0.16), transparent 60%);
  opacity:0.55;
  z-index:0;
}
.pcard > *{position:relative; z-index:1}
.pcard:hover{transform: translateY(-3px); background: rgba(255,255,255,0.075); border-color: rgba(255,255,255,0.20)}
.pcard .tag{
  display:inline-flex;
  align-items:center;
  gap:8px;
  border-radius:999px;
  padding:8px 10px;
  border:1px solid rgba(255,255,255,0.14);
  background:rgba(0,0,0,0.16);
  color: rgba(255,255,255,0.78);
  font-size:12px;
  letter-spacing:0.10em;
  text-transform:uppercase;
}
.pcard h3{
  margin:12px 0 8px;
  font-family:var(--display);
  font-size:20px;
  letter-spacing:-0.01em;
  text-transform:none;
}
.pcard p{color:var(--muted); line-height:1.6; margin:0}
.pcard a{
  display:inline-flex;
  align-items:center;
  gap:8px;
  margin-top: 14px;
  color: rgba(127,231,214,0.92);
  font-size:14px;
}
.pcard a:hover{color: #B9F5EC}
.arrow{transform: translateY(1px)}

/* Marina band */
.band{
  position:relative;
  border-top:1px solid rgba(255,255,255,0.10);
  border-bottom:1px solid rgba(255,255,255,0.10);
  background:
    linear-gradient(120deg, rgba(7,11,20,0.70), rgba(7,11,20,0.35)),
    url("../images/marina.jpg") center/cover no-repeat;
}
.band .card{background: rgba(11,16,32,0.72)}
.band .section-head p.sub{color: rgba(255,255,255,0.72)}

/* Steps */
.steps{
  display:grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 14px;
}
.step{
  border-radius: 18px;
  border: 1px solid rgba(255,255,255,0.12);
  background: rgba(255,255,255,0.06);
  padding: 16px;
}
.step .num{
  font-family:var(--display);
  font-size:20px;
  color: rgba(200,169,106,0.92);
}
.step strong{
  display:block;
  margin-top: 6px;
  letter-spacing:0.08em;
  text-transform:uppercase;
  font-size:12px;
  color: rgba(255,255,255,0.86);
}
.step p{
  margin:10px 0 0;
  color:var(--muted);
  line-height:1.6;
  font-size:14px;
}

/* Insights */
.insights{
  display:grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 16px;
}
.insight{
  border-radius: var(--radius);
  border: 1px solid rgba(255,255,255,0.12);
  background: rgba(255,255,255,0.06);
  padding: 18px;
}
.insight time{
  display:block;
  color: var(--faint);
  font-size:12px;
  letter-spacing:0.12em;
  text-transform:uppercase;
}
.insight h3{
  margin:10px 0 10px;
  font-family:var(--display);
  font-size:20px;
  letter-spacing:-0.01em;
  text-transform:none;
}
.insight p{margin:0; color:var(--muted); line-height:1.65}

/* Contact */
.contact-grid{
  display:grid;
  grid-template-columns: 1.1fr 0.9fr;
  gap: 18px;
}
.form{
  display:grid;
  gap: 12px;
}
.field{
  display:grid; gap:8px;
}
label{
  color: rgba(255,255,255,0.78);
  font-size:12px;
  letter-spacing:0.12em;
  text-transform:uppercase;
}
input, textarea{
  width:100%;
  border-radius: 14px;
  border: 1px solid rgba(255,255,255,0.14);
  background: rgba(255,255,255,0.05);
  color: var(--text);
  padding: 12px 12px;
  outline: none;
}
input:focus, textarea:focus{
  border-color: rgba(127,231,214,0.40);
  box-shadow: 0 0 0 4px rgba(127,231,214,0.12);
}
textarea{min-height:120px; resize:vertical}
.smallprint{
  color: var(--faint);
  font-size: 12px;
  line-height:1.5;
}

/* Footer */
.footer{
  border-top: 1px solid rgba(255,255,255,0.10);
  padding: 34px 0;
  color: var(--faint);
  font-size: 13px;
}
.footer-inner{
  display:flex;
  justify-content:space-between;
  gap: 12px;
  flex-wrap:wrap;
}
.footer a{color: rgba(127,231,214,0.90)}
.footer a:hover{color:#B9F5EC}

/* Reveal animations */
.reveal{
  opacity:0;
  transform: translateY(10px);
  transition: opacity .7s ease, transform .7s ease;
}
.reveal.is-visible{
  opacity:1;
  transform: translateY(0);
}

/* Responsive */
@media (max-width: 980px){
  .hero-grid{grid-template-columns: 1fr}
  .hero-card{max-width: 520px}
  .grid-2{grid-template-columns: 1fr}
  .cards{grid-template-columns: 1fr}
  .steps{grid-template-columns: 1fr 1fr}
  .insights{grid-template-columns: 1fr}
  .contact-grid{grid-template-columns: 1fr}
  .brand{min-width:auto}
}
@media (max-width: 760px){
  .nav, .header-cta{display:none}
  .menu-btn{display:inline-grid}
  .mobile-panel{display:none}
  .mobile-panel.open{display:block}
  .hero{min-height: 92vh}
}
