:root{
  --cc-primary:#184e45;
  --cc-primary-600:#113d36;
  --cc-deep:#20333a;
  --cc-accent:#c86a4b;
  --cc-soft:#f3efe8;
  --cc-surface:#fffdf9;
  --cc-text:#21323a;
  --cc-muted:#687780;
  --cc-border:#ddd5c9;
  --cc-disclosure-bg:#ead6a4;
  --cc-disclosure-text:#2f2517;
}

body{
  color:var(--cc-text);
  background:linear-gradient(180deg,#fffdf9 0%,#f7f3ec 100%);
  font-family:"Trebuchet MS","Segoe UI",sans-serif;
}

h1,h2,h3,h4,h5,h6{
  font-family:Georgia,"Times New Roman",serif;
}

.navbar{
  border-bottom:1px solid rgba(24,78,69,.12);
  background:rgba(255,253,249,.92) !important;
  backdrop-filter:blur(10px);
}

.brand{
  font-weight:700;
  letter-spacing:.2px;
}

.atention{
  font-weight:700;
  font-style:normal;
  font-size:2rem;
  color:#ffe9d6;
  text-align:center;
}

.hero-shell{
  background:
    radial-gradient(circle at top left, rgba(200,106,75,.18), transparent 32%),
    radial-gradient(circle at top right, rgba(24,78,69,.12), transparent 30%);
}

.hero-tag{
  display:inline-flex;
  align-items:center;
  padding:.45rem .9rem;
  border-radius:999px;
  background:rgba(24,78,69,.09);
  color:var(--cc-primary);
  font-size:.92rem;
  font-weight:700;
  letter-spacing:.03em;
}

.custom-form-control{
  margin-bottom:15px;
  padding-left:16px;
  border:1px solid var(--cc-border);
  background:var(--cc-surface);
  font-size:14px;
  height:48px;
  display:block;
  width:100%;
  box-sizing:border-box;
  color:var(--cc-text);
  border-radius:16px;
}

.custom-form-control:focus{
  outline:none;
  border-color:rgba(24,78,69,.45);
  box-shadow:0 0 0 4px rgba(24,78,69,.08);
}

.custom-form-group label{
  color:var(--cc-text);
  margin-left:8px;
  text-align:left;
  font-weight:400;
  font-size:14px;
  cursor:pointer;
  display:inline-block;
}

.mandatory{
  color:#b24332;
  font-size:16px;
  font-weight:400;
  margin-left:8px;
}

.custom-form-group{
  display:flex;
  margin-top:16px;
  align-items:flex-start;
}

.custom-form-group input{
  border:1px solid #ccc;
  background:#fff;
  margin:4px 0 10px 0;
  width:15px !important;
  height:15px !important;
  flex:0 0 auto;
}

footer{
  background-color:var(--cc-deep);
}

footer p{
  color:#f3efe8;
}

.footer-list{
  display:flex;
  flex-wrap:wrap;
  gap:14px;
  list-style:none;
  padding:0;
  margin:15px 0;
}

.footer-list li a{
  text-decoration:none;
  color:#fff;
}

.footer-list li a:hover{
  color:#f3c8b8;
}

.logo{
  max-width:260px;
}

.text-block{
  background-color:#fff;
  border-radius:20px;
  padding:24px;
  border:1px solid rgba(24,78,69,.08);
}

.text-main-block{
  background:linear-gradient(180deg,#faf6ef 0%,#f3efe8 100%);
}

.page-disclosure-top{
  background:var(--cc-disclosure-bg);
  color:var(--cc-disclosure-text);
  font-size:1rem;
  font-weight:800;
  letter-spacing:.08em;
  padding:12px 16px;
  text-align:center;
  text-transform:uppercase;
}

.page-disclosure-bottom{
  background:#fff;
  border-radius:12px;
  color:var(--cc-disclosure-text);
  font-size:1rem;
  font-weight:800;
  line-height:1.5;
  margin-bottom:1.5rem;
  padding:14px 18px;
  text-transform:uppercase;
}

.btn-cc{
  background:var(--cc-primary);
  color:#fff;
  border:1px solid var(--cc-primary);
}

.btn-cc:hover{
  background:var(--cc-primary-600);
  color:#fff;
  border-color:var(--cc-primary-600);
}

.btn-outline-cc{
  border:1.5px solid var(--cc-primary);
  color:var(--cc-primary);
  background:#fff;
}

.btn-outline-cc:hover{
  background:rgba(24,78,69,.06);
  color:var(--cc-primary);
}

.btn-pill{
  border-radius:999px;
  width:100%;
  padding:10px 14px;
  margin-top:10px;
}

.card-ghost{
  border:1px solid var(--cc-border);
  border-radius:24px;
  background:rgba(255,255,255,.7);
}

.aside-sticky{
  position:sticky;
  top:88px;
}

.aside-block{
  background-color:rgba(255,250,244,.92);
  border-radius:24px;
  border:1px solid var(--cc-border);
  padding:1.35rem;
}

.aside-dark{
  background:linear-gradient(180deg,#29444d 0%,#20333a 100%);
  color:#fff;
}

.aside-dark .btn-outline-cc{
  border-color:#fff;
  color:#17353a;
  background:#fff5ef;
  font-weight:700;
}

.aside-dark .btn-outline-cc:hover{
  background:#ffe7d7;
}

.hero-img{
  border-radius:24px;
  overflow:hidden;
  border:1px solid rgba(24,78,69,.08);
}

.hero-photo{
  width:100%;
  display:block;
  object-fit:cover;
  min-height:340px;
}

.lead-cc{
  font-size:1.125rem;
  color:var(--cc-muted);
  max-width:48rem;
}

.kicker{
  color:var(--cc-muted);
  font-size:.9rem;
}

.section-soft{
  background:var(--cc-soft);
}

.shadow-soft{
  box-shadow:0 18px 40px rgba(32,51,58,.08);
}

.feature-stack{
  display:grid;
  gap:14px;
}

.feature-item{
  display:flex;
  align-items:flex-start;
  gap:12px;
}

.feature-badge{
  width:32px;
  height:32px;
  border-radius:50%;
  background:rgba(24,78,69,.12);
  color:var(--cc-primary);
  display:inline-flex;
  align-items:center;
  justify-content:center;
  font-weight:700;
  flex:0 0 auto;
}

.list-check{
  padding-left:1.25rem;
}

.list-check li{
  margin-bottom:.8rem;
}

.area-card,
.info-card{
  height:100%;
  padding:1.2rem;
  border-radius:20px;
  background:#fff;
  border:1px solid rgba(24,78,69,.08);
}

.area-card h3,
.info-card h3{
  margin-bottom:.55rem;
}

.section-copy{
  max-width:42rem;
}

.disclosure-panel,
.info-banner,
.legal-card{
  background:rgba(255,250,244,.95);
  border:1px solid var(--cc-border);
  border-radius:20px;
  padding:1.2rem 1.3rem;
}

.disclosure-panel p:last-child,
.info-banner p:last-child,
.legal-card p:last-child{
  margin-bottom:0;
}

.mini-links{
  display:flex;
  flex-wrap:wrap;
  gap:12px;
  margin-top:.9rem;
}

.mini-links a,
.legal-card a,
.info-banner a{
  color:var(--cc-primary);
}

.footer-banner{
  margin:1rem 0 1.25rem;
  background:rgba(255,255,255,.08);
  border-color:rgba(255,255,255,.14);
}

.footer-banner p,
.footer-banner a{
  color:#fff;
}

.legal-shell{
  padding:3rem 0 4.5rem;
}

.legal-layout{
  display:grid;
  gap:1.5rem;
}

.legal-card h1{
  margin-bottom:1rem;
}

.legal-card h2{
  font-size:1.3rem;
  margin-top:1.5rem;
}

.legal-card ul{
  padding-left:1.25rem;
}

.legal-card li{
  margin-bottom:.7rem;
}

.legal-meta{
  display:flex;
  flex-wrap:wrap;
  gap:12px;
  margin-bottom:1rem;
  color:var(--cc-muted);
  font-size:.95rem;
}

.legal-back{
  margin-top:1.25rem;
}

.top-nav-links{
  display:flex;
  flex-wrap:wrap;
  gap:12px;
  font-size:.95rem;
}

.top-nav-links a{
  color:var(--cc-primary);
  text-decoration:none;
}

.top-nav-links a:hover{
  text-decoration:underline;
}

@media (max-width: 991.98px){
  .aside-sticky{
    position:static;
  }
}

@media (max-width: 575.98px){
  .page-disclosure-top,
  .page-disclosure-bottom{
    font-size:.92rem;
    letter-spacing:.04em;
  }

  .logo{
    max-width:210px;
  }

  .hero-photo{
    min-height:260px;
  }

  .mini-links,
  .top-nav-links{
    flex-direction:column;
    align-items:flex-start;
    gap:8px;
  }
}
