:root {
  --navy:#040A44;
  --blue:#43699B;
  --sky:#83C7F1;
  --paper:#FFFFFF;
  --ink:rgba(4,10,68,.88)
}
* {
  box-sizing:border-box
}
body {
  margin:0;
  font-family:system-ui,-apple-system,Segoe UI,Roboto,Arial,Helvetica,sans-serif;
  line-height:1.55;
  background:var(--paper);
  color:var(--navy)
}
img {
  max-width:100%;
  display:block
}
a {
  color:inherit
}
.header {
  position:sticky;
  top:0;
  z-index:20;
  background:rgba(255,255,255,.92);
  backdrop-filter:saturate(1.2) blur(8px);
  border-bottom:1px solid rgba(4,10,68,.10)
}
.header-inner {
  max-width:1100px;
  margin:0 auto;
  padding:16px 20px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:20px
}
.brand {
  display:flex;
  align-items:center;
  justify-content:flex-start;
  gap:12px;
  text-decoration:none;
  flex:0 0 auto
}
.brand img {
  height:115px;
  width:auto;
  display:block;
  flex-shrink:0
}
.nav {
  display:flex;
  gap:10px;
  flex-wrap:wrap;
  align-items:center;
  justify-content:flex-end
}
.nav .btn-link {
  appearance:none;
  border:1px solid rgba(67,105,155,.55);
  background:rgba(131,199,241,.28);
  padding:10px 14px;
  border-radius:14px;
  font-weight:750;
  text-decoration:none;
  display:inline-flex;
  gap:8px;
  align-items:center;
  cursor:pointer
}
.nav .btn-link:hover {
  filter:brightness(.98)
}
.nav .btn-link:active {
  transform:translateY(1px)
}
.nav .btn-link:focus-visible {
  outline:3px solid rgba(67,105,155,.45);
  outline-offset:2px
}
.container {
  max-width:1100px;
  margin:0 auto;
  padding:34px 18px
}
.hero {
  position:relative;
  border-radius:24px;
  overflow:hidden;
  min-height:360px;
  display:flex;
  align-items:flex-end
}
.hero img {
  position:absolute;
  inset:0;
  width:100%;
  height:100%;
  object-fit:cover
}
.hero::after {
  content:"";
  position:absolute;
  inset:0;
  background:linear-gradient(90deg,rgba(4,10,68,.78),rgba(4,10,68,.25),rgba(4,10,68,.00))
}
.hero .hero-content {
  position:relative;
  z-index:2;
  padding:34px;
  max-width:640px;
  color:#fff
}
.hero h1 {
  margin:0 0 10px;
  font-size:42px;
  line-height:1.1
}
.hero p {
  margin:0 0 18px;
  font-size:17px;
  opacity:.94
}
.hero .hero-actions {
  display:flex;
  gap:12px;
  flex-wrap:wrap
}
.hero .btn-primary {
  border:0;
  background:var(--sky);
  color:var(--navy);
  padding:12px 16px;
  border-radius:16px;
  font-weight:800;
  cursor:pointer;
  text-decoration:none;
  display:inline-flex;
  align-items:center;
  gap:10px
}
.hero .btn-primary:hover {
  filter:brightness(.97)
}
.hero .btn-primary:active {
  transform:translateY(1px)
}
.hero .btn-primary:focus-visible {
  outline:3px solid rgba(255,255,255,.55);
  outline-offset:2px
}
.section {
  margin-top:34px
}
.section-head {
  display:flex;
  align-items:flex-end;
  justify-content:space-between;
  gap:14px;
  flex-wrap:wrap
}
.section-head h2 {
  margin:0;
  font-size:26px
}
.section-head p {
  margin:0;
  color:var(--ink)
}
.grid {
  display:grid;
  gap:16px
}
.grid.cards {
  grid-template-columns:repeat(4,minmax(0,1fr));
  margin-top:14px
}
.card {
  border:1px solid rgba(4,10,68,.10);
  border-radius:20px;
  padding:16px;
  background:#fff;
  box-shadow:0 12px 32px rgba(0,0,0,.06);
  min-height:200px;
  display:flex;
  flex-direction:column;
  gap:10px
}
.card:nth-child(2n):not(.solid) {
  background:rgba(131,199,241,.15)
}
.card .thumb {
  border-radius:16px;
  overflow:hidden;
  aspect-ratio:16/10;
  background:rgba(131,199,241,.15)
}
.card .thumb img {
  width:100%;
  height:100%;
  object-fit:cover
}
.card h3 {
  margin:2px 0 0;
  font-size:18px;
  display:flex;
  align-items:center;
  gap:10px
}
.card p {
  margin:0;
  color:var(--ink)
}
.badge {
  display:inline-flex;
  align-items:center;
  gap:8px;
  background:rgba(131,199,241,.22);
  border:1px solid rgba(67,105,155,.40);
  padding:8px 12px;
  border-radius:999px;
  font-weight:750
}
.split {
  display:grid;
  grid-template-columns:1.1fr .9fr;
  gap:18px;
  margin-top:14px
}
.about-photo {
  border-radius:24px;
  overflow:hidden;
  aspect-ratio:16/11;
  border:1px solid rgba(4,10,68,.10)
}
.about-photo img {
  width:100%;
  height:100%;
  object-fit:cover
}
.panel {
  border:1px solid rgba(4,10,68,.10);
  border-radius:24px;
  padding:18px;
  background:#fff;
  box-shadow:0 12px 32px rgba(0,0,0,.06)
}
.panel h3 {
  margin:0 0 10px;
  font-size:20px
}
.panel ul {
  margin:0;
  padding-left:18px
}
.panel li {
  margin:6px 0
}
.form {
  display:flex;
  flex-direction:column;
  gap:12px
}
.form label {
  display:flex;
  flex-direction:column;
  gap:6px;
  font-weight:750
}
.form input,.form textarea,.form select {
  padding:12px 14px;
  border-radius:14px;
  border:1px solid rgba(4,10,68,.18);
  font-size:16px;
  outline:none;
  min-height:46px
}
.form textarea {
  min-height:120px;
  resize:vertical
}
.form input[type="email"]:invalid,.form textarea:invalid {
  border-color:rgba(200,30,30,.7)
}
.form input[type="email"]:valid {
  border-color:rgba(67,105,155,.55)
}
.form input:focus-visible,.form textarea:focus-visible,.form select:focus-visible {
  border-color:rgba(67,105,155,.75);
  box-shadow:0 0 0 4px rgba(131,199,241,.28)
}
.form .row {
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap:12px;
  flex-wrap:wrap
}
.help {
  min-height:18px;
  font-size:13px;
  color:var(--ink)
}
.has-error .help {
  color:#b00020
}
.counter {
  font-size:13px;
  color:var(--ink)
}
.review-list {
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:16px;
  margin-top:14px
}
.review {
  position:relative;
  border:1px solid rgba(4,10,68,.10);
  border-radius:20px;
  padding:16px;
  background:#fff;
  box-shadow:0 12px 32px rgba(0,0,0,.06);
  cursor:pointer;
  transition:transform .12s ease, box-shadow .12s ease
}
.review:hover {
  transform:translateY(-2px);
  box-shadow:0 16px 38px rgba(0,0,0,.08)
}
.review.is-active {
  border-color:rgba(67,105,155,.65);
  box-shadow:0 18px 44px rgba(0,0,0,.10)
}
.review h3 {
  margin:0 0 6px;
  font-size:16px
}
.review .meta {
  font-size:12px;
  color:var(--ink)
}
.stars {
  color:#d7a700;
  letter-spacing:2px;
  font-size:18px;
  line-height:1
}
.footer {
  margin-top:42px;
  border-top:1px solid rgba(4,10,68,.10);
  background:rgba(131,199,241,.08)
}
.footer-inner {
  max-width:1100px;
  margin:0 auto;
  padding:18px;
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:16px;
  flex-wrap:wrap
}
.footer .col {
  min-width:240px
}
.footer h4 {
  margin:0 0 8px
}
.footer p {
  margin:6px 0;
  color:var(--ink)
}
.footer a {
  text-decoration:none
}
.footer a:hover {
  text-decoration:underline
}
@media (max-width:600px) {
.header-inner {
    flex-direction:column;
    align-items:flex-start;
    justify-content:flex-start
}
.nav {
    width:100%;
    justify-content:flex-start
}
.hero {
    min-height:420px
}
.hero .hero-content {
    padding:22px
}
.hero h1 {
    font-size:34px
}
.grid.cards {
    grid-template-columns:1fr
}
.split {
    grid-template-columns:1fr
}
.review-list {
    grid-template-columns:1fr
}

}
@media (min-width:600px) and (max-width:1024px) {
.grid.cards {
    grid-template-columns:repeat(2,minmax(0,1fr))
}
.split {
    grid-template-columns:1fr
}

}
.nav .btn-link {
  background:transparent
}
.nav button.btn-link {
  font:inherit
}
.modal.hidden {
  display:none
}
.modal {
  position:fixed;
  inset:0;
  z-index:1000;
  background:rgba(0,0,0,.55);
  display:flex;
  align-items:center;
  justify-content:center;
  padding:18px
}
.modal-card {
  width:min(520px,100%);
  background:var(--paper);
  border:1px solid rgba(4,10,68,.15);
  border-radius:14px;
  box-shadow:0 18px 60px rgba(0,0,0,.18);
  padding:18px;
  position:relative
}
.modal-close {
  position:absolute;
  top:10px;
  right:10px;
  border:1px solid rgba(4,10,68,.15);
  background:transparent;
  border-radius:10px;
  padding:8px;
  cursor:pointer
}
.modal-close:focus-visible {
  outline:3px solid rgba(67,105,155,.35)
}
.review-head {
  display:flex;
  gap:12px;
  align-items:center;
  margin-bottom:6px
}
.avatar {
  width:44px;
  height:44px;
  border-radius:50%;
  object-fit:cover;
  border:1px solid rgba(4,10,68,.12)
}
.title-wrap h3 {
  margin:0
}
.title-wrap .meta {
  font-size:13px;
  opacity:.75;
  margin-top:2px
}
.header-inner {
  min-height:64px
}
.header {
  transition:background .25s ease, box-shadow .25s ease
}
.header.is-compact {
  box-shadow:0 6px 20px rgba(0,0,0,.08)
}
.header.is-compact .header-inner {
  padding:10px 20px
}
.header.is-compact .brand img {
  height:115px;
  width:auto;
  display:block;

}
.nav .btn-link {
  appearance:none;
  border:1px solid rgba(67,105,155,.45);
  background:transparent;
  padding:10px 16px;
  border-radius:14px;
  font-weight:700;
  text-decoration:none;
  display:inline-flex;
  align-items:center;
  gap:8px;
  cursor:pointer;
  transition:background .2s ease,color .2s ease,transform .15s ease,box-shadow .15s ease;

}
.nav .btn-link:hover {
  background:rgba(131,199,241,.35);
  color:var(--navy);
  transform:translateY(-1px);
  box-shadow:0 6px 16px rgba(0,0,0,.08);

}
.nav .btn-link:active {
  transform:translateY(0);
  box-shadow:0 3px 10px rgba(0,0,0,.12);

}
.nav .btn-link:focus-visible {
  outline:3px solid rgba(67,105,155,.45);
  outline-offset:3px;

}
.login-btn {
  width:100%;
  display:flex;
  align-items:center;
  justify-content:space-between;
  background:var(--blue);
  color:#fff;
  border:0;

}
.login-btn:hover {
  filter:brightness(.97)
}
.login-btn:active {
  transform:translateY(1px)
}
.login-icon {
  display:inline-flex;
  align-items:center;
  justify-content:center;
  width:36px;
  height:36px;
  border-radius:10px;
  background:rgba(255,255,255,.18);

}
.btn-login {
  background:var(--blue);
  color:#fff;
  border:0;
  padding:10px 14px;
  border-radius:14px;
  display:inline-flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;

}
.btn-login:hover {
  filter:brightness(.97)
}
.btn-login:active {
  transform:translateY(1px)
}
.nav .btn-login {
  background-color: var(--blue) !important;
  color: #ffffff !important;
  border: 1px solid rgba(0,0,0,.15) !important;

}
.nav .btn-login span, .nav .btn-login i {
  color:#ffffff !important;

}
.review [data-delete] {
  position:absolute;
  top:12px;
  right:12px;
  padding:6px 10px;
  font-size:13px;

}
.footer {
  background: linear-gradient(180deg, rgba(131,199,241,.10), rgba(131,199,241,.06));

}
.footer-inner {
  padding:24px 18px;

}
.footer .col {
  padding:14px;
  border-radius:18px;
  background: rgba(255,255,255,.70);
  border:1px solid rgba(4,10,68,.10);
  box-shadow: 0 10px 26px rgba(0,0,0,.05);

}
.footer .col + .col {
  margin-left:0;

}
.footer h4 {
  font-size:16px;
  letter-spacing:.2px;

}
.footer .contact-row {
  display:flex;
  align-items:flex-start;
  gap:10px;
  margin:10px 0;

}
.footer .contact-row i {
  width:18px;
  margin-top:2px;
  opacity:.9;

}
.contact-link {
  text-decoration:none;
  color:inherit;
  display:inline-block;

}
.contact-link:hover {
  text-decoration:underline;
  text-underline-offset:3px;

}
.contact-link:focus-visible {
  outline:3px solid rgba(67,105,155,.45);
  outline-offset:3px;
  border-radius:10px;

}
