/* malacodermatoustjo.info — smart learning · Vitoria-Gasteiz
   Academic + nature blend — Plus Jakarta Sans × Lora
   Palette: forest green, lime, ochre, off-white */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{
  --forest:#1A3A2E; --forest-2:#264C3F; --forest-3:#0F2A20;
  --lime:#B8D85E; --lime-2:#C7E47C; --lime-3:#9CC340;
  --ochre:#C68A2E; --ochre-2:#DBA055; --rust:#A05A2E;
  --paper:#F5F1E8; --paper-2:#EDE6D7; --paper-3:#E1D8C2;
  --ink:#1F1A14; --slate:#5A4F3F; --muted:#8E8169;
  --line:rgba(31,26,20,.12); --line-d:rgba(31,26,20,.2);
  --t:cubic-bezier(.2,.7,.2,1);
}
html{scroll-behavior:smooth;-webkit-font-smoothing:antialiased}
body{font-family:'Plus Jakarta Sans',sans-serif;font-size:16.5px;line-height:1.65;color:var(--ink);background:var(--paper);overflow-x:hidden}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
button{font:inherit;cursor:pointer;border:0;background:none;color:inherit}
.container{max-width:1240px;margin:0 auto;padding:0 32px}
@media(max-width:720px){.container{padding:0 20px}}

/* ===== Type ===== */
h1,h2,h3,h4{font-family:'Plus Jakarta Sans',sans-serif;font-weight:700;color:var(--forest);letter-spacing:-.02em}
h1{font-size:clamp(2.6rem,5.5vw,4.8rem);line-height:1.04}
h2{font-size:clamp(2rem,3.4vw,3.2rem);line-height:1.1}
h3{font-size:1.55rem;line-height:1.2}
.serif{font-family:'Lora',serif;font-style:italic;font-weight:400;color:var(--ochre)}
h1 em,h2 em,h3 em{font-family:'Lora',serif;font-style:italic;font-weight:400;color:var(--ochre)}
.tag{font-family:'Lora',serif;font-style:italic;color:var(--ochre);font-size:1.15rem}
.k-line{font-size:.78rem;letter-spacing:.18em;text-transform:uppercase;color:var(--forest);font-weight:600}

/* ===== Header ===== */
.site-header{position:fixed;top:0;left:0;right:0;z-index:90;padding:18px 0;transition:all .35s var(--t)}
.site-header.scrolled{background:rgba(245,241,232,.92);backdrop-filter:blur(12px);box-shadow:0 1px 0 var(--line)}
.header-inner{display:flex;align-items:center;justify-content:space-between;gap:24px}
.brand{font-family:'Plus Jakarta Sans',sans-serif;font-weight:800;font-size:1.35rem;color:var(--forest);letter-spacing:-.02em;display:inline-flex;align-items:center;gap:8px}
.brand .leaf{display:inline-block;width:26px;height:26px;background:var(--lime);border-radius:50% 50% 50% 4px;transform:rotate(-32deg);box-shadow:inset -2px 0 0 rgba(0,0,0,.06)}
.brand .nm{position:relative;top:-1px}
.brand .sl{color:var(--ochre);font-family:'Lora',serif;font-style:italic;font-weight:500}
.nav{display:flex;align-items:center;gap:26px}
.nav a{font-size:.95rem;font-weight:500;color:var(--ink);padding:6px 0;position:relative;transition:color .2s}
.nav a:hover,.nav a.active{color:var(--forest)}
.nav a::after{content:"";position:absolute;left:0;bottom:0;height:2px;background:var(--ochre);width:0;transition:width .3s var(--t)}
.nav a:hover::after,.nav a.active::after{width:100%}
.nav-toggle{display:none;width:42px;height:42px;border-radius:50%;background:var(--forest);color:#fff;align-items:center;justify-content:center;flex-direction:column;gap:4px}
.nav-toggle span{width:16px;height:1.5px;background:#fff}
@media(max-width:980px){
  .nav{position:fixed;top:0;right:-100%;width:82%;height:100vh;background:var(--forest);flex-direction:column;justify-content:center;gap:28px;transition:right .4s var(--t);padding:60px 40px}
  .nav a{color:#fff;font-size:1.45rem}
  .nav.open{right:0}
  .nav-toggle{display:flex}
}

/* ===== Buttons ===== */
.btn{display:inline-flex;align-items:center;gap:10px;padding:14px 24px;border-radius:8px;font-size:.94rem;font-weight:600;transition:all .3s var(--t);position:relative}
.btn-forest{background:var(--forest);color:#fff}
.btn-forest:hover{background:var(--forest-3);transform:translateY(-2px);box-shadow:0 12px 24px rgba(26,58,46,.25)}
.btn-lime{background:var(--lime);color:var(--forest)}
.btn-lime:hover{background:var(--lime-2);transform:translateY(-2px);box-shadow:0 12px 24px rgba(184,216,94,.4)}
.btn-ochre{background:var(--ochre);color:#fff}
.btn-ochre:hover{background:var(--ochre-2);transform:translateY(-2px)}
.btn-outline{border:1.5px solid var(--forest);color:var(--forest)}
.btn-outline:hover{background:var(--forest);color:#fff}
.btn-text{padding:14px 0;color:var(--forest);border-radius:0;font-weight:600;position:relative}
.btn-text::after{content:"";position:absolute;left:0;bottom:8px;height:2px;width:100%;background:var(--ochre);transform:scaleX(.4);transform-origin:left;transition:transform .25s var(--t)}
.btn-text:hover::after{transform:scaleX(1)}

/* ===== Hero ===== */
.hero{padding:160px 0 96px;position:relative;overflow:hidden}
.hero::before{content:"";position:absolute;top:-100px;right:-100px;width:600px;height:600px;background:radial-gradient(circle,rgba(184,216,94,.3),transparent 60%);filter:blur(40px);pointer-events:none}
.hero::after{content:"";position:absolute;bottom:-100px;left:-100px;width:500px;height:500px;background:radial-gradient(circle,rgba(198,138,46,.18),transparent 60%);filter:blur(40px);pointer-events:none}
.hero-grid{display:grid;grid-template-columns:1.3fr .9fr;gap:64px;align-items:center}
.hero-left .tag{margin-bottom:18px;display:inline-block}
.hero h1{margin-bottom:32px}
.hero h1 .draw{position:relative;display:inline-block}
.hero h1 .draw::after{content:"";position:absolute;bottom:.04em;left:-4px;right:-4px;height:14px;background:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 200 14' preserveAspectRatio='none'%3E%3Cpath d='M2 9 Q 50 2, 100 7 T 198 5' stroke='%23B8D85E' stroke-width='4' fill='none' stroke-linecap='round'/%3E%3C/svg%3E") no-repeat center/100% 100%;pointer-events:none;z-index:-1}
.hero-lead{font-size:1.16rem;color:var(--slate);max-width:560px;line-height:1.7;margin-bottom:36px}
.hero-cta{display:flex;gap:16px;flex-wrap:wrap;align-items:center}
.hero-right{position:relative}
.hero-card-stack{position:relative;padding-top:24px}
.hero-card{position:relative;background:#fff;padding:24px;border-radius:18px;border:1px solid var(--line);box-shadow:0 30px 80px rgba(31,26,20,.08);overflow:hidden}
.hero-card .img{aspect-ratio:5/4;border-radius:12px;overflow:hidden;margin-bottom:16px}
.hero-card .img img{width:100%;height:100%;object-fit:cover}
.hero-card .meta{display:flex;justify-content:space-between;align-items:center;font-size:.84rem}
.hero-card .meta .ch{padding:4px 10px;background:var(--lime);color:var(--forest);border-radius:999px;font-weight:600;font-size:.74rem;letter-spacing:.06em;text-transform:uppercase}
.hero-card .meta .dur{color:var(--slate)}
.hero-card h4{font-family:'Plus Jakarta Sans',sans-serif;color:var(--forest);font-size:1.2rem;margin:8px 0 6px;font-weight:700}
.hero-card p{font-size:.92rem;color:var(--slate)}
.hero-card.behind{position:absolute;top:0;right:-30px;width:74%;transform:rotate(4deg);z-index:-1;opacity:.85}

.hero-meta{display:grid;grid-template-columns:repeat(4,1fr);gap:0;margin-top:80px;padding:32px 0;border-top:1.5px solid var(--ink);border-bottom:1.5px solid var(--ink)}
.hero-meta .m{padding:0 28px;border-right:1px solid var(--line)}
.hero-meta .m:first-child{padding-left:0}
.hero-meta .m:last-child{border-right:0;padding-right:0}
.hero-meta .m .v{font-size:2.6rem;font-weight:700;color:var(--forest);line-height:1;letter-spacing:-.03em}
.hero-meta .m .v .sm{font-size:1.4rem;color:var(--ochre);font-family:'Lora',serif;font-style:italic;font-weight:400}
.hero-meta .m .l{font-size:.86rem;color:var(--slate);margin-top:6px}
@media(max-width:980px){.hero-grid{grid-template-columns:1fr;gap:48px}.hero-meta{grid-template-columns:repeat(2,1fr)}}

/* ===== Sections ===== */
.section{padding:96px 0;position:relative}
.section-tight{padding:56px 0}
.section-forest{background:var(--forest);color:#fff;position:relative;overflow:hidden}
.section-forest h1,.section-forest h2,.section-forest h3,.section-forest h4{color:#fff}
.section-forest .tag{color:var(--lime)}
.section-forest h1 em,.section-forest h2 em,.section-forest h3 em{color:var(--lime)}
.section-forest::before{content:"";position:absolute;top:-100px;right:-100px;width:500px;height:500px;background:radial-gradient(circle,rgba(184,216,94,.15),transparent 60%);border-radius:50%}
.section-paper{background:var(--paper-2)}

.s-head{margin-bottom:64px;max-width:840px}
.s-head .tag{margin-bottom:12px;display:block;font-size:1.2rem}
.s-head h2{margin-bottom:18px}
.s-head .lead{color:var(--slate);font-size:1.1rem;line-height:1.7;max-width:680px}

/* ===== Course catalog ===== */
.filters{display:flex;gap:10px;flex-wrap:wrap;margin-bottom:48px;padding:8px;background:#fff;border-radius:14px;border:1px solid var(--line);width:fit-content;max-width:100%}
.fpill{padding:10px 18px;border-radius:9px;font-size:.9rem;font-weight:600;color:var(--slate);transition:all .25s var(--t);cursor:pointer}
.fpill:hover{color:var(--ink);background:var(--paper-2)}
.fpill.active{background:var(--forest);color:#fff}

.courses{display:grid;grid-template-columns:repeat(3,1fr);gap:28px}
.cs{position:relative;background:#fff;border-radius:18px;overflow:hidden;border:1px solid var(--line);transition:all .4s var(--t);display:flex;flex-direction:column}
.cs:hover{transform:translateY(-6px);box-shadow:0 22px 50px rgba(31,26,20,.1);border-color:var(--lime-3)}
.cs .ph{aspect-ratio:16/9;overflow:hidden;position:relative}
.cs .ph img{width:100%;height:100%;object-fit:cover;transition:transform .8s var(--t)}
.cs:hover .ph img{transform:scale(1.06)}
.cs .rib{position:absolute;top:14px;left:14px;padding:5px 11px;background:var(--ochre);color:#fff;border-radius:6px;font-size:.7rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;z-index:1;box-shadow:0 2px 8px rgba(0,0,0,.15)}
.cs .rib.cer{background:var(--forest)}
.cs .rib.exp{background:var(--rust)}
.cs .body{padding:24px 26px 26px;display:flex;flex-direction:column;flex:1}
.cs .cat{font-family:'Lora',serif;font-style:italic;color:var(--ochre);font-size:.94rem;margin-bottom:8px}
.cs h3{font-size:1.32rem;margin-bottom:10px;line-height:1.25}
.cs p{color:var(--slate);font-size:.94rem;margin-bottom:18px;flex:1}
.cs .meta-row{display:flex;justify-content:space-between;align-items:center;padding-top:18px;border-top:1px dashed var(--line);font-size:.84rem;color:var(--slate)}
.cs .meta-row .price{font-weight:700;color:var(--forest);font-size:1.1rem}
@media(max-width:980px){.courses{grid-template-columns:repeat(2,1fr)}}
@media(max-width:620px){.courses{grid-template-columns:1fr}}

/* ===== Method (paper cards) ===== */
.method{display:grid;grid-template-columns:repeat(4,1fr);gap:24px}
.mt{position:relative;padding:30px 26px;background:#fff;border-radius:14px;border:1px solid var(--line);transition:all .35s var(--t)}
.mt::before{content:"";position:absolute;top:0;left:0;right:0;height:6px;background:var(--lime);border-radius:14px 14px 0 0}
.mt:nth-child(2)::before{background:var(--ochre)}
.mt:nth-child(3)::before{background:var(--forest)}
.mt:nth-child(4)::before{background:var(--rust)}
.mt:hover{transform:translateY(-4px);box-shadow:0 18px 40px rgba(31,26,20,.08)}
.mt .n{font-family:'Lora',serif;font-style:italic;font-size:.96rem;color:var(--ochre);margin-bottom:14px;font-weight:500}
.mt h3{font-size:1.3rem;margin-bottom:10px}
.mt p{color:var(--slate);font-size:.94rem}
@media(max-width:820px){.method{grid-template-columns:repeat(2,1fr)}}
@media(max-width:520px){.method{grid-template-columns:1fr}}

/* ===== Two-column reading layout ===== */
.read-grid{display:grid;grid-template-columns:240px 1fr;gap:72px;align-items:start}
.read-toc{position:sticky;top:120px;padding:24px;border-left:2px solid var(--ochre);background:#fff;border-radius:0 12px 12px 0}
.read-toc .k-line{margin-bottom:14px}
.read-toc ul{list-style:none}
.read-toc ul li{margin-bottom:8px}
.read-toc ul a{font-size:.94rem;color:var(--slate);padding:4px 0;display:block;border-bottom:1px solid transparent;transition:all .2s}
.read-toc ul a:hover,.read-toc ul a.active{color:var(--forest);border-bottom-color:var(--ochre)}
.read-content h3{font-size:1.6rem;margin:48px 0 14px}
.read-content h3:first-child{margin-top:0}
.read-content p{color:var(--ink);font-size:1.04rem;line-height:1.8;margin-bottom:16px;max-width:680px}
.read-content p .serif{font-family:'Lora',serif;font-style:italic;color:var(--ochre);font-size:1.06rem}
.read-content blockquote{border-left:4px solid var(--lime);padding:14px 24px;margin:24px 0 24px;font-family:'Lora',serif;font-style:italic;color:var(--forest);font-size:1.18rem;background:rgba(184,216,94,.08);border-radius:0 8px 8px 0}
.read-content ul{padding-left:24px;margin-bottom:24px;max-width:680px}
.read-content ul li{padding:6px 0;color:var(--slate)}
.read-content ul li::marker{color:var(--ochre)}
@media(max-width:820px){.read-grid{grid-template-columns:1fr;gap:32px}.read-toc{position:relative;top:0}}

/* ===== Faculty cards ===== */
.faculty{display:grid;grid-template-columns:repeat(3,1fr);gap:32px}
.fc{position:relative;background:#fff;border-radius:18px;overflow:hidden;border:1px solid var(--line);transition:all .35s var(--t)}
.fc:hover{transform:translateY(-5px);box-shadow:0 22px 48px rgba(31,26,20,.1)}
.fc .ph{aspect-ratio:1/1;overflow:hidden;background:var(--paper-2);position:relative}
.fc .ph::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 55%,rgba(31,26,20,.55))}
.fc .ph img{width:100%;height:100%;object-fit:cover;transition:transform .8s var(--t)}
.fc:hover .ph img{transform:scale(1.05)}
.fc .badge-loc{position:absolute;top:14px;right:14px;padding:5px 11px;background:rgba(245,241,232,.95);color:var(--forest);border-radius:999px;font-size:.7rem;font-weight:600;letter-spacing:.08em;text-transform:uppercase;z-index:1;backdrop-filter:blur(6px)}
.fc .info{padding:22px 24px 26px}
.fc h3{font-size:1.3rem;margin-bottom:4px}
.fc .role{font-family:'Lora',serif;font-style:italic;color:var(--ochre);font-size:.96rem;margin-bottom:12px}
.fc p{color:var(--slate);font-size:.92rem;line-height:1.55}
.fc .tg{display:flex;flex-wrap:wrap;gap:6px;margin-top:14px}
.fc .tg span{font-size:.74rem;padding:3px 9px;background:var(--paper-2);color:var(--forest);border-radius:999px;font-weight:600}
@media(max-width:980px){.faculty{grid-template-columns:repeat(2,1fr)}}
@media(max-width:560px){.faculty{grid-template-columns:1fr}}

/* ===== Agenda / vertical timeline ===== */
.agenda{position:relative;padding-left:60px}
.agenda::before{content:"";position:absolute;left:24px;top:14px;bottom:14px;width:2px;background:linear-gradient(180deg,var(--lime),var(--ochre),var(--rust))}
.ev{position:relative;padding:32px 32px 32px 0;margin-bottom:14px;background:#fff;border-radius:14px;border:1px solid var(--line);transition:all .35s var(--t)}
.ev::before{content:"";position:absolute;left:-44px;top:38px;width:14px;height:14px;border-radius:50%;background:var(--lime);box-shadow:0 0 0 5px var(--paper),0 0 0 6px var(--forest);z-index:1}
.ev:hover{transform:translateX(6px);box-shadow:0 14px 30px rgba(31,26,20,.08)}
.ev .grid{display:grid;grid-template-columns:140px 1fr auto;gap:30px;align-items:center;padding-left:36px}
.ev .date{font-family:'Plus Jakarta Sans',sans-serif;font-weight:700;color:var(--forest)}
.ev .date .d{font-size:2rem;line-height:1;letter-spacing:-.02em}
.ev .date .m{font-size:.8rem;letter-spacing:.1em;text-transform:uppercase;color:var(--ochre);margin-top:2px}
.ev .det h3{font-size:1.25rem;margin-bottom:6px}
.ev .det p{color:var(--slate);font-size:.94rem}
.ev .tag-c{font-family:'Lora',serif;font-style:italic;color:var(--ochre);font-size:.84rem;display:block;margin-top:4px}
@media(max-width:720px){.ev .grid{grid-template-columns:1fr;gap:14px;padding-left:20px}.agenda{padding-left:36px}.ev::before{left:-32px}}

/* ===== Quote section ===== */
.qsec{padding:80px 0;text-align:center}
.qsec blockquote{font-family:'Lora',serif;font-style:italic;font-size:clamp(1.5rem,2.6vw,2.3rem);line-height:1.4;color:var(--forest);max-width:880px;margin:0 auto 28px;font-weight:400;position:relative}
.qsec blockquote::before{content:"\201C";font-family:'Lora',serif;font-size:8rem;color:var(--lime);position:absolute;left:50%;transform:translateX(-50%);top:-70px;line-height:1;font-weight:400}
.qsec cite{display:block;font-style:normal;font-size:.86rem;letter-spacing:.14em;text-transform:uppercase;color:var(--ochre);font-weight:600}

/* ===== Page hero ===== */
.page-hero{padding:140px 0 56px;position:relative;border-bottom:1px solid var(--line)}
.page-hero .crumb{font-size:.82rem;letter-spacing:.1em;text-transform:uppercase;color:var(--slate);margin-bottom:18px;font-weight:600}
.page-hero .crumb a{color:var(--forest);border-bottom:1.5px solid var(--ochre)}
.page-hero h1{max-width:920px;margin-bottom:20px}
.page-hero .lead{max-width:680px;font-size:1.16rem;color:var(--slate);line-height:1.7}

/* ===== Form ===== */
.contact-grid{display:grid;grid-template-columns:1fr 1.3fr;gap:56px;align-items:start}
@media(max-width:980px){.contact-grid{grid-template-columns:1fr}}
.ci{padding:0}
.ci h3{font-size:1.9rem;margin-bottom:18px}
.ci .lead{color:var(--slate);margin-bottom:36px;font-size:1.04rem;line-height:1.7;max-width:480px}
.cinfo{padding:24px 28px;background:#fff;border-radius:14px;margin-bottom:14px;border:1px solid var(--line);display:flex;gap:18px;align-items:flex-start;transition:all .25s var(--t)}
.cinfo:hover{border-color:var(--ochre);transform:translateY(-2px)}
.cinfo .ic{width:42px;height:42px;border-radius:50%;background:var(--lime);color:var(--forest);display:flex;align-items:center;justify-content:center;font-weight:700;font-size:.88rem;flex-shrink:0}
.cinfo .x{flex:1}
.cinfo .x .l{font-family:'Lora',serif;font-style:italic;color:var(--ochre);font-size:.92rem;margin-bottom:4px}
.cinfo .x .v,.cinfo .x a{display:block;color:var(--ink);font-size:1.02rem;line-height:1.5}
.cinfo .x a:hover{color:var(--forest)}
.form-w{padding:40px;background:#fff;border-radius:18px;border:1px solid var(--line);box-shadow:0 8px 30px rgba(31,26,20,.05)}
.form-w h3{font-size:1.9rem;margin-bottom:8px}
.form-w .sub{color:var(--slate);margin-bottom:24px}
.frow{display:grid;grid-template-columns:1fr 1fr;gap:16px}
@media(max-width:560px){.frow{grid-template-columns:1fr}}
.field{margin-bottom:18px}
.field label{display:block;font-size:.78rem;font-weight:700;color:var(--forest);margin-bottom:8px;letter-spacing:.06em;text-transform:uppercase}
.field input,.field select,.field textarea{width:100%;padding:14px 16px;background:var(--paper);border:1.5px solid transparent;border-radius:8px;font:inherit;color:var(--ink);transition:all .25s}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--forest);background:#fff}
.field textarea{resize:vertical;min-height:130px}
.fcheck{display:flex;gap:10px;align-items:flex-start;margin-bottom:14px;font-size:.88rem;color:var(--slate)}
.fcheck input{margin-top:4px;accent-color:var(--forest)}
.fcheck a{color:var(--forest);border-bottom:1px solid var(--ochre)}
.form-status{margin-top:14px;font-style:italic;color:var(--forest);font-size:.9rem;font-family:'Lora',serif}

.map-w{margin-top:48px;height:400px;border-radius:18px;overflow:hidden;border:1px solid var(--line)}
.map-w iframe{width:100%;height:100%;border:0;filter:hue-rotate(45deg) saturate(.85) contrast(1.05)}

/* ===== Footer ===== */
.footer{background:var(--forest);color:rgba(255,255,255,.7);padding:80px 0 32px;margin-top:64px;position:relative;overflow:hidden}
.footer::before{content:"";position:absolute;bottom:-100px;right:-100px;width:400px;height:400px;background:radial-gradient(circle,rgba(184,216,94,.15),transparent 60%);border-radius:50%}
.footer .brand{color:#fff;position:relative}
.foot-top{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:40px;padding-bottom:48px;border-bottom:1px solid rgba(255,255,255,.1);position:relative}
.foot-top h5{font-size:.78rem;letter-spacing:.16em;text-transform:uppercase;color:var(--lime);margin-bottom:18px;font-weight:600}
.foot-top p{font-size:.92rem;line-height:1.6;color:rgba(255,255,255,.6);margin-top:14px;max-width:340px}
.foot-top ul{list-style:none}
.foot-top ul li{margin-bottom:10px;font-size:.92rem}
.foot-top ul a:hover{color:var(--lime-2)}
.foot-bot{display:flex;justify-content:space-between;flex-wrap:wrap;gap:20px;padding-top:24px;font-size:.84rem;color:rgba(255,255,255,.5);position:relative}
.foot-bot .ll{display:flex;gap:18px}
.foot-bot .ll a:hover{color:var(--lime-2)}
@media(max-width:820px){.foot-top{grid-template-columns:1fr 1fr;gap:32px}}

/* ===== Cookie ===== */
.cookie{position:fixed;left:20px;right:20px;bottom:20px;max-width:520px;background:#fff;color:var(--ink);padding:24px 28px;border-radius:14px;box-shadow:0 24px 60px rgba(31,26,20,.25);z-index:200;transform:translateY(200%);transition:transform .5s var(--t);border:1px solid var(--line)}
.cookie.show{transform:translateY(0)}
.cookie h4{font-size:1.2rem;margin-bottom:8px;color:var(--forest)}
.cookie p{font-size:.88rem;color:var(--slate);margin-bottom:16px;line-height:1.55}
.cookie a{color:var(--forest);border-bottom:1px solid var(--ochre)}
.cookie-actions{display:flex;gap:10px;flex-wrap:wrap}
.cookie .btn{padding:10px 16px;font-size:.85rem}

/* ===== Legal ===== */
.legal{max-width:820px;margin:0 auto;padding:140px 0 80px}
.legal h1{font-size:clamp(2.2rem,4vw,3.2rem);margin-bottom:14px}
.legal .upd{font-size:.78rem;letter-spacing:.12em;text-transform:uppercase;color:var(--ochre);margin-bottom:40px;padding-bottom:24px;border-bottom:1px solid var(--line);font-weight:600;font-style:italic;font-family:'Lora',serif}
.legal h2{font-size:1.45rem;margin:36px 0 14px;color:var(--forest)}
.legal p,.legal li{color:var(--slate);font-size:1rem;line-height:1.75;margin-bottom:12px}
.legal ul{padding-left:24px;margin-bottom:22px}
.legal a{color:var(--forest);border-bottom:1px solid var(--ochre)}
.legal table{width:100%;border-collapse:collapse;margin:18px 0 28px;font-size:.92rem}
.legal th,.legal td{padding:12px 14px;text-align:left;border-bottom:1px solid var(--line);vertical-align:top}
.legal th{font-size:.78rem;letter-spacing:.1em;text-transform:uppercase;color:var(--forest);background:var(--paper-2);font-weight:700}
.legal code{font-size:.86rem;background:var(--paper-2);padding:3px 8px;border-radius:5px;color:var(--rust)}

/* ===== CTA ===== */
.cta-card{padding:72px 56px;background:var(--forest);color:#fff;border-radius:18px;display:grid;grid-template-columns:1.5fr 1fr;gap:40px;align-items:center;position:relative;overflow:hidden}
.cta-card::before{content:"";position:absolute;top:-100px;right:-100px;width:400px;height:400px;background:radial-gradient(circle,rgba(184,216,94,.25),transparent 60%);border-radius:50%}
.cta-card h2{color:#fff;font-size:2.2rem;position:relative}
.cta-card h2 em{font-family:'Lora',serif;font-style:italic;color:var(--lime);font-weight:400}
.cta-card p{color:rgba(255,255,255,.78);margin-top:12px;position:relative;font-size:1.04rem}
.cta-card .ac{display:flex;gap:14px;justify-content:flex-end;flex-wrap:wrap;position:relative}
@media(max-width:820px){.cta-card{grid-template-columns:1fr;padding:48px 28px}.cta-card .ac{justify-content:flex-start}}

/* ===== Reveal ===== */
.reveal{opacity:1;transform:translateY(30px);transition:transform .8s var(--t)}
.reveal.in{transform:translateY(0)}
.reveal-l{opacity:1;transform:translateX(-30px);transition:transform .8s var(--t)}
.reveal-l.in{transform:translateX(0)}
.reveal-r{opacity:1;transform:translateX(30px);transition:transform .8s var(--t)}
.reveal-r.in{transform:translateX(0)}
@media(prefers-reduced-motion:reduce){.reveal,.reveal-l,.reveal-r{transform:none;transition:none}}

::selection{background:var(--lime);color:var(--forest)}
