*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{
  --bg:#f5f5f7;
  --surface:#fff;
  --text:#1d1d1f;
  --text2:#636366;
  --text3:#6e6e73;
  --accent:#27789a;
  --accent-soft:rgba(39,120,154,.08);
  --border:rgba(0,0,0,.06);
  --radius:12px;
  --shadow:0 1px 8px rgba(0,0,0,.04);
  --gap:20px;
  --content:1400px;
  --gutter:32px;
}
body{font-family:'Inter',system-ui,-apple-system,sans-serif;background:var(--bg);color:var(--text);line-height:1.5;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}

/* Hero */
.hero{
  background:linear-gradient(160deg,#0a1628 0%,#1B3A5C 50%,#2E86AB 100%);
  color:#fff;text-align:center;
  padding:64px var(--gutter) 88px;
  position:relative;overflow:hidden;
}
.hero-content{position:relative;z-index:1}
.hero h1{
  font-size:clamp(2rem,4.5vw,3rem);
  font-weight:800;letter-spacing:-.025em;
  margin-bottom:8px;color:#fff;
}
.hero p{font-size:1rem;color:rgba(255,255,255,.75);font-weight:400}
.hero-wave{position:absolute;bottom:-1px;left:0;width:100%;line-height:0}
.hero-wave svg{display:block;width:100%;height:40px}

/* Main layout */
.main{max-width:var(--content);margin:-48px auto 0;padding:0 var(--gutter);position:relative;z-index:2;display:flex;flex-direction:column;gap:var(--gap)}

/* Stats */
.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--gap)}
.stat{
  background:var(--surface);border-radius:var(--radius);
  padding:24px;box-shadow:var(--shadow);
}
.stat-value{font-size:2rem;font-weight:800;letter-spacing:-.03em;color:var(--text);line-height:1.1}
.stat-label{font-size:.75rem;color:var(--text3);font-weight:500;text-transform:uppercase;letter-spacing:.05em;margin-top:6px}

/* Sections */
.card{background:var(--surface);border-radius:var(--radius);padding:24px;box-shadow:var(--shadow)}
.card h2{font-size:.9rem;font-weight:600;color:var(--text2);margin-bottom:16px}

/* Subscribe */
.subscribe-card{
  display:flex;align-items:center;gap:16px;flex-wrap:wrap;
  padding:10px 14px;
  background:var(--surface);border-radius:var(--radius);box-shadow:var(--shadow);
}
.subscribe-label{font-size:.85rem;color:var(--text3);font-weight:500;white-space:nowrap}
.subscribe-form{display:flex;gap:8px;flex:1;min-width:260px}
.subscribe-form input[type="email"]{
  flex:1;padding:7px 12px;
  border:1px solid var(--border);border-radius:8px;
  font-size:.8rem;font-family:inherit;
  background:var(--bg);color:var(--text);
  transition:border-color .2s,box-shadow .2s;
}
.subscribe-form input[type="email"]:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft);background:var(--surface)}
.subscribe-form input[type="email"]::placeholder{color:var(--text3)}
.subscribe-form button{
  padding:7px 14px;border:none;border-radius:8px;
  background:var(--accent);
  color:#fff;font-size:.8rem;font-weight:600;font-family:inherit;
  cursor:pointer;transition:background .2s;white-space:nowrap;
}
.subscribe-form button:hover{background:#1f6a8a}
.subscribe-form button:disabled{opacity:.4;cursor:not-allowed}
.subscribe-msg{font-size:.8rem}
.subscribe-msg:empty{display:none}
.subscribe-msg.ok{color:#248a3d}
.subscribe-msg.err{color:#d70015}

/* Filter bar */
.filter-bar{
  position:sticky;top:0;z-index:20;
  background:rgba(245,245,247,.82);
  backdrop-filter:saturate(180%) blur(20px);
  -webkit-backdrop-filter:saturate(180%) blur(20px);
  border-bottom:1px solid transparent;
  padding:12px 0;
  margin-left:calc(var(--gutter) * -1);margin-right:calc(var(--gutter) * -1);padding-left:var(--gutter);padding-right:var(--gutter);
  transition:box-shadow .2s,border-color .2s;
}
.filter-bar.scrolled{box-shadow:0 1px 10px rgba(0,0,0,.06);border-bottom-color:var(--border)}
.filter-inner{display:flex;gap:12px;align-items:center}
.search-wrap{flex:1;position:relative}
.search-wrap svg{position:absolute;left:12px;top:50%;transform:translateY(-50%);width:15px;height:15px;color:var(--text3)}
.search-wrap input{
  width:100%;padding:9px 12px 9px 36px;
  border:1px solid var(--border);border-radius:8px;
  font-size:.85rem;font-family:inherit;
  background:var(--surface);color:var(--text);
  transition:border-color .2s,box-shadow .2s;
}
.search-wrap input:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft)}
.search-wrap input::placeholder{color:var(--text3)}
.filter-select{
  padding:9px 34px 9px 14px;
  border:1px solid var(--border);border-radius:8px;
  font-size:.85rem;font-family:inherit;
  background:var(--surface);color:var(--text);
  appearance:none;
  background-image:url("data:image/svg+xml,%3Csvg width='10' height='6' viewBox='0 0 10 6' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M1 1l4 4 4-4' stroke='%236e6e73' stroke-width='1.5' stroke-linecap='round'/%3E%3C/svg%3E");
  background-repeat:no-repeat;
  background-position:right 12px center;
  cursor:pointer;transition:border-color .2s;
}
.filter-select:focus{outline:none;border-color:var(--accent)}
.result-count{font-size:.8rem;color:var(--text3);font-weight:500;white-space:nowrap;min-width:72px;text-align:right}

/* Table */
.table-card{background:var(--surface);border-radius:var(--radius);box-shadow:var(--shadow);overflow:hidden}
.table-wrap{overflow-x:auto;-webkit-overflow-scrolling:touch}
table{width:100%;border-collapse:collapse;font-size:.85rem}
thead th{
  text-align:left;padding:11px 14px;font-size:.7rem;font-weight:600;
  text-transform:uppercase;letter-spacing:.06em;color:var(--text3);
  border-bottom:1px solid var(--border);white-space:nowrap;
  position:sticky;top:0;background:var(--surface);z-index:3;
}
tbody tr{border-bottom:1px solid var(--border);transition:background .15s}
tbody tr:last-child{border-bottom:none}
tbody tr:hover{background:rgba(46,134,171,.03)}
tbody td{padding:12px 14px;vertical-align:top}
.col-num{color:var(--text3);font-size:.78rem;font-variant-numeric:tabular-nums;width:36px;text-align:center}
.col-boat{min-width:170px}
.col-boat .boat-name{display:block;font-weight:600;color:var(--text);line-height:1.3}
.col-boat .boat-type{display:block;font-size:.78rem;color:var(--text3);margin-top:1px}
.col-sail{white-space:nowrap;color:var(--text2);font-variant-numeric:tabular-nums}
.col-skipper{color:var(--text);font-weight:500}
.col-club{color:var(--text2);max-width:220px}
.col-crew{min-width:200px}
.crew-pill{
  display:inline-block;background:var(--bg);
  border-radius:5px;padding:2px 8px;margin:2px 3px 2px 0;
  font-size:.76rem;color:var(--text2);white-space:nowrap;
}
.no-crew{color:var(--text3)}
tbody .col-date{white-space:nowrap;font-variant-numeric:tabular-nums;color:var(--text3);font-size:.8rem;text-align:right}
.new-badge{
  display:inline-block;background:#248a3d;color:#fff;
  font-size:.62rem;font-weight:700;text-transform:uppercase;letter-spacing:.03em;
  padding:2px 6px;border-radius:4px;margin-right:5px;vertical-align:middle;
}
tr.is-new{background:rgba(52,199,89,.03)}
tr.is-new:hover{background:rgba(52,199,89,.06)}

/* Category rows */
.cat-separator td{
  padding:24px 14px 10px;
  font-size:.82rem;font-weight:700;
  letter-spacing:.03em;
  color:var(--text);
  background:var(--bg);
  border-bottom:1px solid var(--border);
}
.cat-separator .cat-count{font-weight:400;color:var(--text3);margin-left:2px}
.cat-separator:first-child td{padding-top:14px}

/* Sticky category label (position:fixed on body, JS-controlled) */
.sticky-cat-label{
  position:fixed;
  z-index:25;
  padding:10px 14px;
  font-size:.82rem;font-weight:700;
  letter-spacing:.03em;
  color:var(--text);
  background:var(--bg);
  border-bottom:1px solid var(--border);
  display:none;
  box-sizing:border-box;
}

/* Footer */
footer{
  text-align:center;padding:32px var(--gutter);margin-top:40px;
  border-top:1px solid var(--border);
  color:var(--text3);font-size:.78rem;
}
footer a{color:var(--accent);text-decoration:none;font-weight:500}
footer a:hover{text-decoration:underline}
footer p{margin:3px 0}

/* Responsive */
@media(max-width:900px){
  :root{--gutter:16px;--gap:12px;--radius:10px}
  .main{margin-top:-36px}
  .hero{padding:40px var(--gutter) 60px}
  .hero h1{font-size:1.6rem;letter-spacing:-.02em}
  .hero p{font-size:.85rem}
  .hero-wave svg{height:28px}
  .stats{grid-template-columns:repeat(2,1fr);gap:10px}
  .stat{padding:16px}
  .stat-value{font-size:1.5rem}
  .stat-label{font-size:.68rem;margin-top:3px}
  .subscribe-card{padding:12px 16px;gap:10px}
  .subscribe-label{display:none}
  .subscribe-form{min-width:0}
  .subscribe-form input[type="email"]{padding:9px 12px}
  .card{padding:20px}
  .filter-inner{flex-wrap:wrap;gap:8px}
  .search-wrap{min-width:100%}
  .filter-select{width:100%}
  table{font-size:.8rem}
  .col-crew,.col-club{display:none}
  thead .col-crew,thead .col-club{display:none}
  tbody td{padding:10px 8px}
  .cat-separator td{padding:18px 8px 8px;font-size:.78rem}
  .sticky-cat-label{padding:8px 8px;font-size:.78rem}
  footer{padding:24px var(--gutter);margin-top:28px}
}
@media(min-width:901px) and (max-width:1100px){
  .col-crew{display:none}
  thead .col-crew{display:none}
}

/* Load animation */
@keyframes fadeUp{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}
.stat{animation:fadeUp .4s ease both}
.stat:nth-child(2){animation-delay:.05s}
.stat:nth-child(3){animation-delay:.1s}
.stat:nth-child(4){animation-delay:.15s}
