/* ==================================================================
   SONRISA PERFECTA® — forms.css
   Styles für formulare.html (lädt zusammen mit sonrisa.css)
   ------------------------------------------------------------------
   Nutzt Brand-Tokens aus sonrisa.css :root
================================================================== */

/* ================ SUBPAGE HERO ================ */
.subpage-hero{
  padding:120px 0 40px;
  position:relative;
  overflow:hidden;
}
.subpage-hero .wrap{position:relative;z-index:2}
.subpage-hero .page-eyebrow{
  font-family:var(--sans);
  font-size:13px;font-weight:600;
  letter-spacing:.28em;text-transform:uppercase;
  color:var(--cyan);
  display:flex;align-items:center;gap:14px;
  margin-bottom:24px;
}
.subpage-hero .page-eyebrow::before{
  content:"";width:36px;height:1px;background:var(--cyan);
}
.subpage-hero h1{
  font-family:var(--display);
  font-weight:400;
  font-size:clamp(40px, 6vw, 88px);
  line-height:.98;
  letter-spacing:-.02em;
  color:var(--cream);
  margin:0 0 24px;
  text-transform:uppercase;
}
.subpage-hero h1 .it{
  font-style:italic;
  font-weight:300;
  text-transform:none;
  color:var(--magenta);
}
.subpage-hero p{
  font-size:clamp(16px, 1.5vw, 19px);
  line-height:1.6;
  color:var(--cream-dim);
  max-width:62ch;
}

/* ================ FORM DOWNLOAD CARDS ================ */
.forms-grid{
  display:grid;
  grid-template-columns:repeat(2, 1fr);
  gap:24px;
  position:relative;
  z-index:5;
  margin-bottom:60px;
}
.form-card{
  background:linear-gradient(180deg, var(--canvas-2) 0%, var(--canvas-3) 100%);
  border:1px solid rgba(0,176,235,.18);
  border-radius:var(--radius);
  padding:42px 38px;
  display:flex;
  flex-direction:column;
  position:relative;
  overflow:hidden;
  transition:transform .35s ease, border-color .35s ease;
}
.form-card::before{
  content:"";position:absolute;top:0;left:0;right:0;height:3px;
}
.form-card.is-data::before{background:var(--cyan)}
.form-card.is-treatment::before{background:var(--magenta)}
.form-card:hover{
  transform:translateY(-4px);
  border-color:rgba(0,176,235,.4);
}
.form-card-icon{
  width:60px;height:60px;
  border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  margin-bottom:24px;
}
.form-card.is-data .form-card-icon{
  background:rgba(0,176,235,.14);
  color:var(--cyan);
}
.form-card.is-treatment .form-card-icon{
  background:rgba(229,0,125,.14);
  color:var(--magenta);
}
.form-card-icon svg{width:28px;height:28px}
.form-card h2{
  font-family:var(--display);font-weight:400;
  font-size:clamp(24px, 2.4vw, 30px);
  line-height:1.1;letter-spacing:-.01em;
  text-transform:uppercase;color:var(--cream);
  margin:0 0 16px;
  white-space:nowrap;
}
@media (max-width:680px){
  .form-card h2{
    white-space:normal;
    font-size:22px;
    overflow-wrap:break-word;
    word-break:break-word;
    hyphens:auto;
  }
}
@media (max-width:380px){
  .form-card h2{font-size:19px}
}
.form-card p{
  color:var(--cream-dim);font-size:15px;line-height:1.6;
  margin:0 0 28px;flex:1;
}

/* ================ FORM CARD BUTTONS ================ */
/* Spezielle Anpassung: btn-block für volle Card-Breite */
.form-card .btn{
  display:inline-flex;align-items:center;justify-content:center;gap:10px;
}
.form-card .btn-block{width:100%}
.form-card .btn svg{width:16px;height:16px;flex-shrink:0}

/* ================ NOTICE BLOCKS ================ */
.notice{
  padding:22px 26px;
  border-radius:14px;
  margin:22px 0;
  display:flex;gap:18px;align-items:flex-start;
}
.notice-icon{width:26px;height:26px;flex-shrink:0}
.notice h4{
  font-family:var(--display);
  font-weight:500;font-size:18px;
  color:var(--cream);
  margin:0 0 6px;letter-spacing:.01em;
}
.notice p{
  margin:0;font-size:14.5px;line-height:1.6;
  color:var(--cream-dim);
}
.notice p strong{color:var(--cream)}
.notice p a{color:var(--cyan);border-bottom:1px solid var(--cyan);transition:color .25s ease, border-color .25s ease}
.notice p a:hover{color:var(--magenta);border-bottom-color:var(--magenta)}
.notice-cyan{
  background:rgba(0,176,235,.08);
  border-left:3px solid var(--cyan);
}
.notice-cyan .notice-icon{color:var(--cyan)}
.notice-magenta{
  background:rgba(229,0,125,.08);
  border-left:3px solid var(--magenta);
}
.notice-magenta .notice-icon{color:var(--magenta)}

/* ================ RESPONSIVE ================ */
@media (max-width:980px){
  .subpage-hero{padding:160px 0 40px}
  .forms-grid{grid-template-columns:1fr;gap:18px;margin-top:0}
  .form-card{padding:36px 28px}
}
@media (max-width:560px){
  .form-card{padding:32px 24px}
  .subpage-hero{padding:140px 0 30px}
  .notice{padding:20px 22px;gap:14px}
  .notice-icon{width:22px;height:22px}
}
@media (max-width:380px){
  .form-card{padding:26px 20px}
  .subpage-hero h1{font-size:38px;line-height:1.02}
}
