:root{
  --obsidian:#050806;
  --forest:#0b1813;
  --pine:#10241d;
  --moss:#9cc8ad;
  --champagne:#d9bd7a;
  --sand:#f3efe6;
  --muted:#b9b0a2;
  --line:rgba(255,255,255,.13);
  --line-strong:rgba(217,189,122,.42);
  --danger:#ff8b8b;
  --max:1160px;
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family:"Avenir Next","Manrope","Inter","Segoe UI",Arial,sans-serif;
  background:
    radial-gradient(circle at 12% 0%, rgba(217,189,122,.18), transparent 32%),
    radial-gradient(circle at 92% 8%, rgba(156,200,173,.14), transparent 32%),
    linear-gradient(180deg,#050806 0%,#07110e 44%,#050806 100%);
  color:var(--sand);
  line-height:1.55;
  -webkit-font-smoothing:antialiased;
}

a{color:inherit}
.wrap{width:min(var(--max),92vw);margin:auto}

.site-header{
  position:sticky;
  top:0;
  z-index:40;
  background:rgba(5,8,6,.82);
  border-bottom:1px solid var(--line);
  backdrop-filter:blur(14px);
}

.nav{
  min-height:74px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:24px;
}

.brand{
  text-decoration:none;
  font-weight:950;
  letter-spacing:-.055em;
  font-size:24px;
  line-height:1;
}
.brand small{
  display:block;
  margin-top:5px;
  color:var(--muted);
  font-size:10px;
  letter-spacing:.18em;
  text-transform:uppercase;
}
.brand span{color:var(--champagne)}

.navlinks{
  display:flex;
  align-items:center;
  gap:18px;
  color:var(--muted);
  font-size:14px;
}
.navlinks a{text-decoration:none}
.navlinks a:hover{color:var(--sand)}

.header-cta{
  border:1px solid var(--line-strong);
  padding:12px 16px;
  text-decoration:none;
  font-weight:850;
  background:rgba(217,189,122,.08);
}

.hero{
  position:relative;
  padding:84px 0 48px;
  overflow:hidden;
}

.hero-grid{
  display:grid;
  grid-template-columns:1.05fr .95fr;
  gap:34px;
  align-items:end;
}

.kicker{
  color:var(--moss);
  text-transform:uppercase;
  letter-spacing:.19em;
  font-size:12px;
  font-weight:950;
  margin-bottom:18px;
}

h1,h2,h3,p{margin-top:0}
h1{
  max-width:900px;
  margin-bottom:22px;
  font-size:clamp(42px,7.4vw,84px);
  line-height:.92;
  letter-spacing:-.078em;
}

.hero-lead{
  max-width:760px;
  color:var(--muted);
  font-size:clamp(18px,2.1vw,24px);
  margin-bottom:30px;
}

.actions{display:flex;gap:12px;flex-wrap:wrap}

.btn{
  min-height:52px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding:14px 20px;
  border:1px solid var(--line-strong);
  background:linear-gradient(135deg,rgba(217,189,122,.24),rgba(217,189,122,.06));
  text-decoration:none;
  font-weight:900;
  letter-spacing:-.01em;
  cursor:pointer;
  color:var(--sand);
}
.btn:hover{filter:brightness(1.08)}
.btn.alt{
  border-color:rgba(255,255,255,.18);
  background:rgba(255,255,255,.045);
  color:var(--sand);
}

.signal-panel{
  border:1px solid var(--line);
  background:linear-gradient(180deg,rgba(255,255,255,.07),rgba(255,255,255,.025));
  padding:22px;
  position:relative;
}
.signal-panel:before,
.card:before,
.formbox:before{
  content:"";
  position:absolute;
  top:-1px;
  left:18px;
  width:92px;
  height:1px;
  background:var(--champagne);
}
.metric{
  display:grid;
  grid-template-columns:84px 1fr;
  gap:14px;
  padding:14px 0;
  border-bottom:1px solid var(--line);
}
.metric:last-child{border-bottom:0}
.metric b{
  color:var(--champagne);
  font-size:26px;
  letter-spacing:-.05em;
}
.metric span{color:var(--muted);font-size:14px}

section{padding:58px 0}
.section-head{
  display:flex;
  justify-content:space-between;
  gap:24px;
  align-items:end;
  margin-bottom:24px;
}
h2{
  font-size:clamp(31px,4.5vw,54px);
  line-height:.98;
  letter-spacing:-.058em;
  max-width:760px;
}
.section-lead{
  color:var(--muted);
  font-size:18px;
  max-width:720px;
}

.options{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:16px;
}

.card{
  position:relative;
  min-height:360px;
  border:1px solid var(--line);
  background:
    linear-gradient(180deg,rgba(255,255,255,.066),rgba(255,255,255,.022)),
    var(--forest);
  padding:26px;
  overflow:hidden;
}
.card:after{
  content:"";
  position:absolute;
  right:-60px;
  top:-60px;
  width:160px;
  height:160px;
  border:1px solid rgba(217,189,122,.18);
  transform:rotate(45deg);
}
.card-number{
  color:var(--champagne);
  font-weight:950;
  letter-spacing:.16em;
  font-size:12px;
  margin-bottom:24px;
}
.card h3{
  font-size:28px;
  line-height:1.02;
  letter-spacing:-.045em;
  margin-bottom:14px;
}
.card p{color:var(--muted)}
.tags{display:flex;flex-wrap:wrap;gap:7px;margin-top:20px}
.tag{
  border:1px solid rgba(156,200,173,.34);
  color:var(--moss);
  font-size:11px;
  font-weight:950;
  letter-spacing:.09em;
  text-transform:uppercase;
  padding:6px 8px;
}

.path{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:12px;
}
.step{
  border:1px solid var(--line);
  background:rgba(255,255,255,.035);
  padding:20px;
}
.step b{
  display:block;
  color:var(--champagne);
  font-size:13px;
  letter-spacing:.13em;
  text-transform:uppercase;
  margin-bottom:10px;
}
.step p{color:var(--muted);margin-bottom:0}

.split{
  display:grid;
  grid-template-columns:.9fr 1.1fr;
  gap:22px;
  align-items:start;
}

.formbox{
  position:relative;
  border:1px solid var(--line);
  background:linear-gradient(180deg,rgba(255,255,255,.072),rgba(255,255,255,.028));
  padding:26px;
}

form{display:grid;gap:13px}
.field-grid{display:grid;grid-template-columns:1fr 1fr;gap:13px}
label{
  display:block;
  margin-bottom:7px;
  color:var(--muted);
  font-size:13px;
  font-weight:850;
}
input,select,textarea{
  width:100%;
  min-height:48px;
  border:1px solid rgba(255,255,255,.16);
  background:rgba(0,0,0,.26);
  color:var(--sand);
  padding:12px;
  border-radius:0;
  font:inherit;
}
textarea{min-height:112px}
option{background:#0b1813;color:#fff}
.status{min-height:24px;color:var(--moss);font-weight:850}

.footer{
  border-top:1px solid var(--line);
  padding:34px 0;
  color:var(--muted);
  font-size:14px;
}
.powered{
  margin-top:12px;
  color:rgba(217,189,122,.82);
  font-size:12px;
  letter-spacing:.09em;
  text-transform:uppercase;
}

@media(max-width:920px){
  .hero-grid,.split{grid-template-columns:1fr}
  .options,.path{grid-template-columns:1fr}
  .section-head{display:block}
  .nav{align-items:flex-start;flex-direction:column;padding:16px 0}
  .navlinks{flex-wrap:wrap}
  .field-grid{grid-template-columns:1fr}
  .hero{padding:52px 0 32px}
  .signal-panel{margin-top:10px}
}

/* TYHY_HERO_OPTIONS_V3_START */
h1{
  font-size:clamp(34px,5.2vw,62px)!important;
  line-height:.98!important;
  max-width:790px!important;
}

h2{
  font-size:clamp(27px,3.4vw,42px)!important;
  line-height:1.04!important;
}

.hero{
  padding:54px 0 36px!important;
}

.hero-lead{
  font-size:clamp(16px,1.55vw,20px)!important;
  max-width:720px!important;
  margin-bottom:20px!important;
}

.hero-options{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:10px;
  margin:22px 0 24px;
  max-width:850px;
}

.hero-option{
  position:relative;
  display:block;
  min-height:136px;
  padding:17px 16px 15px;
  border:1px solid var(--line);
  background:
    linear-gradient(180deg,rgba(255,255,255,.07),rgba(255,255,255,.025)),
    rgba(11,24,19,.78);
  text-decoration:none;
  overflow:hidden;
}

.hero-option:before{
  content:"";
  position:absolute;
  top:-1px;
  left:14px;
  width:66px;
  height:1px;
  background:var(--champagne);
}

.hero-option:after{
  content:"";
  position:absolute;
  right:-38px;
  top:-38px;
  width:96px;
  height:96px;
  border:1px solid rgba(217,189,122,.15);
  transform:rotate(45deg);
}

.hero-option small{
  display:block;
  color:var(--moss);
  font-size:10px;
  font-weight:950;
  letter-spacing:.13em;
  text-transform:uppercase;
  margin-bottom:8px;
}

.hero-option b{
  display:block;
  color:var(--sand);
  font-size:18px;
  line-height:1.06;
  letter-spacing:-.035em;
  margin-bottom:7px;
}

.hero-option span{
  display:block;
  color:var(--muted);
  font-size:13px;
  line-height:1.35;
}

.signal-panel{
  align-self:start!important;
  margin-top:6px!important;
}

.metric{
  padding:11px 0!important;
}

.metric b{
  font-size:22px!important;
}

@media(max-width:920px){
  h1{
    font-size:clamp(32px,9vw,48px)!important;
  }
  h2{
    font-size:clamp(26px,7vw,36px)!important;
  }
  .hero{
    padding:38px 0 28px!important;
  }
  .hero-options{
    grid-template-columns:1fr;
    margin:18px 0 20px;
  }
  .hero-option{
    min-height:auto;
  }
}
/* TYHY_HERO_OPTIONS_V3_END */

/* TYHY_HERO_OPTIONS_V3_START */
h1{
  font-size:clamp(34px,5.2vw,62px)!important;
  line-height:.98!important;
  max-width:790px!important;
}

h2{
  font-size:clamp(27px,3.4vw,42px)!important;
  line-height:1.04!important;
}

.hero{
  padding:54px 0 36px!important;
}

.hero-lead{
  font-size:clamp(16px,1.55vw,20px)!important;
  max-width:720px!important;
  margin-bottom:20px!important;
}

.hero-options{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:10px;
  margin:22px 0 24px;
  max-width:850px;
}

.hero-option{
  position:relative;
  display:block;
  min-height:136px;
  padding:17px 16px 15px;
  border:1px solid var(--line);
  background:
    linear-gradient(180deg,rgba(255,255,255,.07),rgba(255,255,255,.025)),
    rgba(11,24,19,.78);
  text-decoration:none;
  overflow:hidden;
}

.hero-option:before{
  content:"";
  position:absolute;
  top:-1px;
  left:14px;
  width:66px;
  height:1px;
  background:var(--champagne);
}

.hero-option:after{
  content:"";
  position:absolute;
  right:-38px;
  top:-38px;
  width:96px;
  height:96px;
  border:1px solid rgba(217,189,122,.15);
  transform:rotate(45deg);
}

.hero-option small{
  display:block;
  color:var(--moss);
  font-size:10px;
  font-weight:950;
  letter-spacing:.13em;
  text-transform:uppercase;
  margin-bottom:8px;
}

.hero-option b{
  display:block;
  color:var(--sand);
  font-size:18px;
  line-height:1.06;
  letter-spacing:-.035em;
  margin-bottom:7px;
}

.hero-option span{
  display:block;
  color:var(--muted);
  font-size:13px;
  line-height:1.35;
}

.signal-panel{
  align-self:start!important;
  margin-top:6px!important;
}

.metric{
  padding:11px 0!important;
}

.metric b{
  font-size:22px!important;
}

@media(max-width:920px){
  h1{
    font-size:clamp(32px,9vw,48px)!important;
  }
  h2{
    font-size:clamp(26px,7vw,36px)!important;
  }
  .hero{
    padding:38px 0 28px!important;
  }
  .hero-options{
    grid-template-columns:1fr;
    margin:18px 0 20px;
  }
  .hero-option{
    min-height:auto;
  }
}
/* TYHY_HERO_OPTIONS_V3_END */

/* TYHY_INKOO_RATSASTUS_V4_START */
.hero-options{
  grid-template-columns:repeat(4,1fr)!important;
  max-width:1040px!important;
}

.hero-option b{
  font-size:16px!important;
}

.hero-option span{
  font-size:12.5px!important;
}

.options{
  grid-template-columns:repeat(4,1fr)!important;
}

.option-system{
  margin-top:24px;
  border:1px solid var(--line);
  background:linear-gradient(180deg,rgba(255,255,255,.055),rgba(255,255,255,.018));
  padding:24px;
}

.option-system-grid{
  display:grid;
  grid-template-columns:1.1fr .9fr;
  gap:22px;
  align-items:start;
}

.option-map{
  display:grid;
  grid-template-columns:repeat(2,1fr);
  gap:10px;
}

.option-pill{
  border:1px solid rgba(255,255,255,.13);
  background:rgba(0,0,0,.18);
  padding:14px;
}

.option-pill small{
  display:block;
  color:var(--moss);
  text-transform:uppercase;
  letter-spacing:.11em;
  font-weight:950;
  font-size:10px;
  margin-bottom:7px;
}

.option-pill b{
  display:block;
  color:var(--sand);
  font-size:16px;
  letter-spacing:-.025em;
}

.option-pill span{
  display:block;
  color:var(--muted);
  font-size:13px;
  margin-top:4px;
}

.program-day{
  border:1px solid var(--line);
  background:
    radial-gradient(circle at 85% 0%,rgba(156,200,173,.11),transparent 34%),
    linear-gradient(180deg,rgba(255,255,255,.062),rgba(255,255,255,.022));
  padding:28px;
  margin-top:18px;
}

.program-day h3{
  font-size:30px;
  letter-spacing:-.045em;
  margin-bottom:10px;
}

.timeline{
  display:grid;
  gap:10px;
  margin-top:20px;
}

.time-row{
  display:grid;
  grid-template-columns:92px 1fr;
  gap:14px;
  padding:13px 0;
  border-bottom:1px solid var(--line);
}

.time-row:last-child{
  border-bottom:0;
}

.time-row b{
  color:var(--champagne);
  font-size:14px;
}

.time-row span{
  color:var(--muted);
  font-size:14px;
}

.price-note{
  margin-top:18px;
  padding:16px;
  border:1px solid rgba(217,189,122,.28);
  background:rgba(217,189,122,.055);
  color:var(--sand);
}

@media(max-width:1100px){
  .hero-options,
  .options{
    grid-template-columns:repeat(2,1fr)!important;
  }
}

@media(max-width:920px){
  .hero-options,
  .options,
  .option-system-grid,
  .option-map{
    grid-template-columns:1fr!important;
  }

  .time-row{
    grid-template-columns:1fr;
    gap:3px;
  }
}
/* TYHY_INKOO_RATSASTUS_V4_END */

/* TYHY_INKOO_RATSASTUS_V4_START */
.hero-options{
  grid-template-columns:repeat(4,1fr)!important;
  max-width:1040px!important;
}

.hero-option b{
  font-size:16px!important;
}

.hero-option span{
  font-size:12.5px!important;
}

.options{
  grid-template-columns:repeat(4,1fr)!important;
}

.option-system{
  margin-top:24px;
  border:1px solid var(--line);
  background:linear-gradient(180deg,rgba(255,255,255,.055),rgba(255,255,255,.018));
  padding:24px;
}

.option-system-grid{
  display:grid;
  grid-template-columns:1.1fr .9fr;
  gap:22px;
  align-items:start;
}

.option-map{
  display:grid;
  grid-template-columns:repeat(2,1fr);
  gap:10px;
}

.option-pill{
  border:1px solid rgba(255,255,255,.13);
  background:rgba(0,0,0,.18);
  padding:14px;
}

.option-pill small{
  display:block;
  color:var(--moss);
  text-transform:uppercase;
  letter-spacing:.11em;
  font-weight:950;
  font-size:10px;
  margin-bottom:7px;
}

.option-pill b{
  display:block;
  color:var(--sand);
  font-size:16px;
  letter-spacing:-.025em;
}

.option-pill span{
  display:block;
  color:var(--muted);
  font-size:13px;
  margin-top:4px;
}

.program-day{
  border:1px solid var(--line);
  background:
    radial-gradient(circle at 85% 0%,rgba(156,200,173,.11),transparent 34%),
    linear-gradient(180deg,rgba(255,255,255,.062),rgba(255,255,255,.022));
  padding:28px;
  margin-top:18px;
}

.program-day h3{
  font-size:30px;
  letter-spacing:-.045em;
  margin-bottom:10px;
}

.timeline{
  display:grid;
  gap:10px;
  margin-top:20px;
}

.time-row{
  display:grid;
  grid-template-columns:92px 1fr;
  gap:14px;
  padding:13px 0;
  border-bottom:1px solid var(--line);
}

.time-row:last-child{
  border-bottom:0;
}

.time-row b{
  color:var(--champagne);
  font-size:14px;
}

.time-row span{
  color:var(--muted);
  font-size:14px;
}

.price-note{
  margin-top:18px;
  padding:16px;
  border:1px solid rgba(217,189,122,.28);
  background:rgba(217,189,122,.055);
  color:var(--sand);
}

@media(max-width:1100px){
  .hero-options,
  .options{
    grid-template-columns:repeat(2,1fr)!important;
  }
}

@media(max-width:920px){
  .hero-options,
  .options,
  .option-system-grid,
  .option-map{
    grid-template-columns:1fr!important;
  }

  .time-row{
    grid-template-columns:1fr;
    gap:3px;
  }
}
/* TYHY_INKOO_RATSASTUS_V4_END */

/* TYHY_CATALOG_EVENT_PAGES_V5_START */
.catalog-grid{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:14px;
}

.event-card{
  position:relative;
  display:flex;
  flex-direction:column;
  min-height:385px;
  border:1px solid var(--line);
  background:
    linear-gradient(180deg,rgba(255,255,255,.07),rgba(255,255,255,.024)),
    rgba(11,24,19,.78);
  padding:24px;
  text-decoration:none;
  overflow:hidden;
}

.event-card:before{
  content:"";
  position:absolute;
  top:-1px;
  left:18px;
  width:84px;
  height:1px;
  background:var(--champagne);
}

.event-card:hover{
  border-color:rgba(217,189,122,.48);
}

.event-meta{
  color:var(--moss);
  font-size:11px;
  font-weight:950;
  letter-spacing:.12em;
  text-transform:uppercase;
  margin-bottom:18px;
}

.event-card h3{
  font-size:24px!important;
  line-height:1.03;
  letter-spacing:-.045em;
  margin-bottom:12px;
}

.event-card p{
  color:var(--muted);
  font-size:14px;
}

.event-facts{
  display:grid;
  gap:8px;
  margin:16px 0 20px;
  color:var(--muted);
  font-size:13px;
}

.event-facts b{
  color:var(--sand);
}

.event-cta-row{
  margin-top:auto;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:10px;
  padding-top:14px;
  border-top:1px solid var(--line);
}

.event-link{
  color:var(--champagne);
  font-weight:950;
  font-size:13px;
}

.event-price{
  color:var(--sand);
  font-weight:950;
  font-size:13px;
}

.hero-options{
  grid-template-columns:repeat(4,1fr)!important;
}

.hero-option{
  min-height:124px!important;
}

.event-hero{
  padding:58px 0 34px;
}

.event-hero-grid{
  display:grid;
  grid-template-columns:1.05fr .95fr;
  gap:26px;
  align-items:start;
}

.event-summary-box{
  border:1px solid var(--line);
  background:linear-gradient(180deg,rgba(255,255,255,.065),rgba(255,255,255,.025));
  padding:24px;
}

.event-summary-box dl{
  margin:0;
  display:grid;
  gap:13px;
}

.event-summary-box div{
  border-bottom:1px solid var(--line);
  padding-bottom:12px;
}

.event-summary-box div:last-child{
  border-bottom:0;
  padding-bottom:0;
}

.event-summary-box dt{
  color:var(--moss);
  font-size:11px;
  font-weight:950;
  text-transform:uppercase;
  letter-spacing:.12em;
  margin-bottom:3px;
}

.event-summary-box dd{
  margin:0;
  color:var(--sand);
  font-weight:850;
}

.program-block{
  border:1px solid var(--line);
  background:
    radial-gradient(circle at 84% 0%,rgba(156,200,173,.10),transparent 32%),
    linear-gradient(180deg,rgba(255,255,255,.06),rgba(255,255,255,.02));
  padding:28px;
}

.timeline{
  display:grid;
  gap:0;
  margin-top:18px;
}

.time-row{
  display:grid;
  grid-template-columns:92px 1fr;
  gap:14px;
  padding:13px 0;
  border-bottom:1px solid var(--line);
}

.time-row:last-child{
  border-bottom:0;
}

.time-row b{
  color:var(--champagne);
}

.time-row span{
  color:var(--muted);
}

.back-link{
  display:inline-flex;
  color:var(--muted);
  text-decoration:none;
  margin-bottom:18px;
  font-weight:850;
}

.back-link:hover{
  color:var(--champagne);
}

.compact-note{
  border:1px solid rgba(217,189,122,.26);
  background:rgba(217,189,122,.055);
  padding:16px;
  color:var(--muted);
}

@media(max-width:1120px){
  .catalog-grid,
  .hero-options{
    grid-template-columns:repeat(2,1fr)!important;
  }
}

@media(max-width:920px){
  .catalog-grid,
  .hero-options,
  .event-hero-grid{
    grid-template-columns:1fr!important;
  }

  .event-card{
    min-height:auto;
  }

  .time-row{
    grid-template-columns:1fr;
    gap:3px;
  }
}
/* TYHY_CATALOG_EVENT_PAGES_V5_END */
