/* ============================================================
   Christine D. A. Hasebrink — Changemaker · Impulse Creator
   Pixelnaher Nachbau (Referenz 1920px). Vanilla CSS.
   ============================================================ */

/* ---------- Fonts ---------- */
@font-face{font-family:'Inter';src:url('../assets/fonts/inter-400.woff2') format('woff2');font-weight:400;font-style:normal;font-display:swap}
@font-face{font-family:'Inter';src:url('../assets/fonts/inter-400-italic.woff2') format('woff2');font-weight:400;font-style:italic;font-display:swap}
@font-face{font-family:'Inter';src:url('../assets/fonts/inter-500.woff2') format('woff2');font-weight:500;font-style:normal;font-display:swap}
@font-face{font-family:'Inter';src:url('../assets/fonts/inter-600.woff2') format('woff2');font-weight:600;font-style:normal;font-display:swap}
@font-face{font-family:'Inter';src:url('../assets/fonts/inter-700.woff2') format('woff2');font-weight:700;font-style:normal;font-display:swap}
@font-face{font-family:'Inter';src:url('../assets/fonts/inter-800.woff2') format('woff2');font-weight:800;font-style:normal;font-display:swap}
@font-face{font-family:'Inter';src:url('../assets/fonts/inter-900.woff2') format('woff2');font-weight:900;font-style:normal;font-display:swap}
@font-face{font-family:'Caveat';src:url('../assets/fonts/caveat-600.woff2') format('woff2');font-weight:600;font-style:normal;font-display:swap}

/* ---------- Tokens ---------- */
:root{
  --ink:#1d1d1f;
  --bg:#ffffff;
  --muted:#5e5e61;
  --muted-2:#8a8a8d;
  --line:#e7e7e7;
  --card-gray:#f1f1f2;
  --pink:#ff65c3;
  --pink-pale:#fed0ed;
  --pink-deep:#d5378b;
  --green:#4abc77;
  --green-dark:#255e3b;

  --gutter:40px;
  --nav-h:88px;

  /* Editorial-Offsets relativ zur wrap-Contentbreite (1840px @1920) */
  --col-offset:37.2%;   /* x≈725 */
  --cv-width:33.2%;     /* ~610px */
  --mot-width:59%;      /* ~1086px */

  font-family:'Inter','Helvetica Neue',Arial,sans-serif;
}

/* ---------- Reset ---------- */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  background:var(--bg);
  color:var(--ink);
  font-family:'Inter','Helvetica Neue',Arial,sans-serif;
  font-size:18px;line-height:1.5;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
img{display:block;max-width:100%;height:auto}
a{color:inherit;text-decoration:none}
button{font:inherit;color:inherit;background:none;border:none;cursor:pointer}
em{font-style:italic}

/* ---------- Layout helpers ---------- */
.wrap{padding-inline:var(--gutter)}
.bleed{width:100%}

/* ============================================================
   NAV
   ============================================================ */
.nav{
  position:fixed;top:0;left:0;right:0;z-index:100;
  height:var(--nav-h);
  display:flex;align-items:center;justify-content:space-between;
  padding-inline:45px;
  border-bottom:1px solid var(--line);
  background:rgba(255,255,255,.82);
  backdrop-filter:saturate(160%) blur(8px);
}
.nav__time{font-size:15px;font-weight:600;letter-spacing:.01em;font-variant-numeric:tabular-nums}
.nav__time .muted{color:var(--muted-2);font-weight:600}
.nav__menu{
  position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);
  display:grid;grid-template-columns:repeat(2,4px);grid-auto-rows:4px;
  gap:4px 7px;
}
.nav__menu span{width:4px;height:4px;border-radius:50%;background:var(--ink);display:block}
.nav__right{display:flex;align-items:center}

/* ---------- Buttons ---------- */
.btn--pill{
  display:inline-flex;align-items:center;justify-content:center;
  background:var(--ink);color:#fff;
  font-size:15px;font-weight:700;letter-spacing:.02em;
  padding:14px 28px;border-radius:999px;
  transition:transform .35s cubic-bezier(.2,.8,.2,1),background .35s;
}
.btn--pill:hover{transform:translateY(-2px);background:#000}

/* ============================================================
   HERO
   ============================================================ */
.hero{
  padding-top:calc(var(--nav-h) + 70px);
  padding-inline:var(--gutter);
  text-align:center;
}
.eyebrow{
  display:flex;align-items:center;justify-content:center;gap:14px;
  font-size:14px;font-weight:700;letter-spacing:.14em;
  text-transform:uppercase;color:var(--ink);
}
.eyebrow .dot{width:9px;height:9px;border-radius:50%;background:var(--green)}
.hero__title{
  margin-top:26px;
  font-weight:800;
  font-size:154px;line-height:.92;
  letter-spacing:-.02em;
  text-transform:uppercase;
  transform:scaleX(1.12);
}
.hero__title .line{display:block;overflow:hidden}
.hero__meta{
  display:flex;justify-content:space-between;align-items:center;
  margin-top:230px;
  font-size:14px;font-weight:600;letter-spacing:.04em;text-transform:uppercase;
}

/* ---------- Sky ---------- */
.sky{margin-top:36px;height:720px}
.sky img{width:100%;height:100%;object-fit:cover;object-position:center 60%}

/* ============================================================
   INTRO STATEMENT
   ============================================================ */
.intro{padding-top:290px}
.intro p{
  font-size:30px;line-height:1.32;font-weight:600;letter-spacing:-.01em;
  max-width:1840px;
}
.intro p + p{margin-top:32px}

/* ============================================================
   EXPERIENCE / CV
   ============================================================ */
.experience{padding-top:680px}
.experience__grid{display:grid;grid-template-columns:var(--col-offset) minmax(0,1fr);align-items:start}
.experience__col{max-width:610px}
.experience__title{margin-top:6px}

/* Große Section-Display-Headlines (SELECTED PROJECTS, MORE ABOUT CHRISTINE, WORK WITH ME) */
.section-head{
  font-weight:800;font-size:86px;line-height:.9;
  letter-spacing:-.02em;text-transform:uppercase;
}
.section-head.center{text-align:center}
.cv{padding:0 0 84px}
.cv + .cv{border-top:1px solid var(--line);padding-top:84px}
.cv__company{font-size:25px;font-weight:800;letter-spacing:-.01em}
.cv__role{margin-top:18px;font-size:20px;font-weight:800;letter-spacing:-.01em}
.cv__desc{margin-top:14px;font-size:20px;line-height:1.55;font-weight:400;color:var(--muted)}

/* ============================================================
   OVAL PORTRAIT
   ============================================================ */
.about-title{margin-top:210px;margin-bottom:56px}
.portrait-oval{
  margin:0 auto 0;
  width:430px;height:560px;
  border-radius:50%;
  overflow:hidden;
}
.portrait-oval img{
  width:100%;height:100%;object-fit:cover;object-position:center 30%;
  transform:scale(var(--zoom,1.04));transform-origin:center;will-change:transform;
}

/* ============================================================
   STORY
   ============================================================ */
.story{padding-top:360px}
.story__inner{max-width:1190px;margin:0 auto}
.story p{font-size:22px;line-height:1.62;font-weight:700;letter-spacing:-.01em}
.story p + p{margin-top:48px}
.story__cta{margin-top:46px;text-align:center}

/* ============================================================
   FEATURED IN
   ============================================================ */
.featured{padding-top:300px}
.section-title{
  font-weight:800;letter-spacing:-.02em;text-transform:uppercase;line-height:1.0;
}
.section-title.center{text-align:center}
.featured .section-title{font-size:64px}
.marquee{
  margin-top:64px;overflow:hidden;
  -webkit-mask-image:linear-gradient(to right,transparent 0,#000 7%,#000 93%,transparent 100%);
  mask-image:linear-gradient(to right,transparent 0,#000 7%,#000 93%,transparent 100%);
}
.marquee__track{display:flex;width:max-content;animation:marquee 45s linear infinite}
.marquee:hover .marquee__track{animation-play-state:paused}
.marquee__group{display:flex;gap:24px;padding-right:24px;flex:0 0 auto}
.marquee .logo-card{flex:0 0 248px;height:232px;aspect-ratio:auto}
@keyframes marquee{from{transform:translateX(0)}to{transform:translateX(-50%)}}
.logo-card{
  background:var(--card-gray);border-radius:16px;
  aspect-ratio:1.05/1;
  display:flex;align-items:center;justify-content:center;
  padding:34px;
}
.logo-card img{
  max-height:64px;max-width:78%;width:auto;object-fit:contain;
  filter:grayscale(1);opacity:.85;
}

/* ============================================================
   LEAD TEXT
   ============================================================ */
.lead{padding-top:150px}
.lead .section-head{margin-bottom:60px}
.lead p{
  max-width:none;margin:0;text-align:left;
  font-size:30px;line-height:1.32;font-weight:600;letter-spacing:-.01em;
}

/* ============================================================
   SERVICE CARDS
   ============================================================ */
.services{padding-top:210px}
.services__grid{display:grid;grid-template-columns:repeat(6,1fr);gap:24px}
.card{
  position:relative;border-radius:22px;
  padding:40px 40px 40px;
  min-height:300px;
  display:flex;flex-direction:column;
  transition:transform .4s cubic-bezier(.2,.8,.2,1);
  overflow:hidden;
}
.card.span-2{grid-column:span 2}
.card.span-3{grid-column:span 3;min-height:262px}
.card:hover{transform:translateY(-6px)}
.card--pink{background:var(--pink)}
.card--pink-pale{background:var(--pink-pale)}
.card--green{background:var(--green)}
.card--pink-deep{background:var(--pink-deep)}
.card--green-dark{background:var(--green-dark)}
.card__label{
  margin-top:auto;
  font-size:13px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;
  color:var(--ink);opacity:.9;
}
.card__title{
  margin-top:14px;
  font-size:30px;font-weight:800;letter-spacing:-.01em;text-transform:uppercase;line-height:1.05;
}
.card__desc{margin-top:18px;font-size:17px;line-height:1.45;font-weight:400;color:var(--ink);opacity:.82;max-width:46ch}
.card--green-dark .card__label,.card--green-dark .card__title{color:#0f1f16}
.card--green-dark .card__desc{color:#cfe0d5;opacity:.9}
.card__actions{position:absolute;top:26px;right:28px;display:flex;align-items:center;gap:14px;z-index:2}
.card__view{
  display:inline-flex;align-items:center;justify-content:center;
  background:var(--ink);color:#fff;font-size:15px;font-weight:700;letter-spacing:.02em;
  padding:14px 28px;border-radius:999px;
  opacity:0;transform:translateX(10px);pointer-events:none;
  transition:opacity .35s cubic-bezier(.2,.8,.2,1),transform .35s cubic-bezier(.2,.8,.2,1);
}
.card:hover .card__view{opacity:1;transform:none;pointer-events:auto}
.card__plus{
  position:relative;flex:none;
  width:54px;height:54px;border-radius:50%;
  background:#2a2a2c;
  transition:transform .4s cubic-bezier(.2,.8,.2,1);
}
.card__plus::before,.card__plus::after{
  content:'';position:absolute;left:50%;top:50%;background:#fff;border-radius:2px;
  transform:translate(-50%,-50%);
}
.card__plus::before{width:16px;height:2px}
.card__plus::after{width:2px;height:16px}
.card:hover .card__plus{transform:rotate(90deg)}

/* ============================================================
   SERVICE MODAL
   ============================================================ */
.cardmodal{position:fixed;inset:0;z-index:1000;display:none;align-items:center;justify-content:center;padding:40px}
.cardmodal.open{display:flex}
.cardmodal__backdrop{position:absolute;inset:0;background:rgba(40,40,42,.55);-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}
.cardmodal__box{
  position:relative;z-index:1;width:min(1120px,94vw);max-height:88vh;overflow-y:auto;
  border-radius:26px;padding:60px 70px 64px;background:var(--pink);color:var(--ink);
  animation:modalIn .42s cubic-bezier(.2,.8,.2,1);
}
.cardmodal__box.is-dark{color:#eef3ef}
@keyframes modalIn{from{opacity:0;transform:translateY(22px) scale(.985)}to{opacity:1;transform:none}}
.cardmodal__close{
  position:absolute;top:32px;right:36px;width:54px;height:54px;border-radius:50%;background:#2a2a2c;flex:none;
}
.cardmodal__close::before,.cardmodal__close::after{
  content:'';position:absolute;left:50%;top:50%;width:18px;height:2px;background:#fff;border-radius:2px;transform-origin:center;
}
.cardmodal__close::before{transform:translate(-50%,-50%) rotate(45deg)}
.cardmodal__close::after{transform:translate(-50%,-50%) rotate(-45deg)}
.cardmodal__title{
  font-size:40px;font-weight:800;letter-spacing:-.01em;text-transform:uppercase;line-height:1.05;
  padding-bottom:24px;margin-bottom:40px;border-bottom:1px solid currentColor;
}
.cardmodal__box:not(.is-dark) .cardmodal__title{border-color:rgba(0,0,0,.18)}
.cardmodal__box.is-dark .cardmodal__title{border-color:rgba(255,255,255,.25)}
.cardmodal__grid{display:grid;grid-template-columns:1fr 460px;gap:64px;align-items:start}
.modal-list{list-style:none}
.modal-list li{position:relative;padding-left:30px;margin-bottom:28px;font-size:21px;line-height:1.42;font-weight:500}
.modal-list li:last-child{margin-bottom:0}
.modal-list li::before{content:'';position:absolute;left:6px;top:11px;width:8px;height:8px;border-radius:50%;background:currentColor}
.modal-list strong{font-weight:800}
.cardmodal__media img{width:100%;border-radius:18px;display:block}

/* ============================================================
   MOTIVATION
   ============================================================ */
.motivation{padding-top:240px}
.motivation__grid{
  display:grid;grid-template-columns:var(--col-offset) 1fr;
  align-items:start;
}
.motivation__title{font-size:52px}
.motivation__body{max-width:var(--mot-width)}
.motivation__body p{font-size:22px;line-height:1.45;font-weight:600;letter-spacing:-.01em}
.motivation__body p + p{margin-top:24px}
.signature{
  font-family:'Caveat',cursive;font-weight:600;
  font-size:64px;line-height:1;margin-top:36px;color:var(--ink);
}

/* ---------- Laugh bleed ---------- */
.laugh{margin-top:210px;height:640px}
.laugh img{width:100%;height:100%;object-fit:cover;object-position:center 38%}

/* ============================================================
   TESTIMONIALS
   ============================================================ */
.testimonials{padding-top:230px}
.testimonials .section-title{font-size:64px;line-height:1.0}
.testimonials__track{
  margin-top:80px;
  display:flex;gap:24px;
  overflow-x:auto;scroll-snap-type:x proximity;
  padding-inline:var(--gutter);padding-bottom:20px;
  cursor:grab;scrollbar-width:none;
}
.testimonials__track::-webkit-scrollbar{display:none}
.testimonials__track.dragging{cursor:grabbing}
.testi{
  flex:0 0 450px;scroll-snap-align:start;
  background:#f6f6f7;border:1px solid #ececed;border-radius:18px;
  padding:40px 44px;min-height:300px;
  display:flex;flex-direction:column;
}
.testi header h4{font-size:21px;font-weight:700;letter-spacing:-.01em}
.testi header span{display:block;margin-top:4px;font-size:16px;color:var(--muted-2);font-weight:500}
.testi p{
  margin-top:42px;
  font-size:17px;line-height:1.5;font-weight:700;letter-spacing:.005em;text-transform:uppercase;
}

/* ---------- Leopard bleed ---------- */
.leopard{margin-top:210px;height:740px}
.leopard img{width:100%;height:100%;object-fit:cover;object-position:center 42%}

/* ============================================================
   THREE TRUE TRAITS (Accordion)
   ============================================================ */
.traits{padding-top:240px}
.traits .section-title{font-size:42px}
.accordion{max-width:1100px;margin:64px auto 0}
.acc-item{margin-bottom:16px}
.acc-head{
  width:100%;display:flex;align-items:center;justify-content:space-between;
  background:var(--card-gray);border-radius:12px;
  padding:24px 30px;
  font-size:14px;font-weight:700;letter-spacing:.04em;text-transform:uppercase;
  transition:background .3s;
}
.acc-head:hover{background:#eaeaeb}
.acc-icon{position:relative;width:18px;height:18px;flex:none}
.acc-icon::before,.acc-icon::after{
  content:'';position:absolute;left:50%;top:50%;background:var(--ink);border-radius:2px;
  transform:translate(-50%,-50%);transition:transform .3s;
}
.acc-icon::before{width:14px;height:2px}
.acc-icon::after{width:2px;height:14px}
.acc-item.open .acc-icon::after{transform:translate(-50%,-50%) rotate(90deg)}
.acc-body{max-height:0;overflow:hidden;transition:max-height .45s ease}
.acc-body p{padding:18px 30px 6px;font-size:18px;line-height:1.5;color:var(--muted)}

/* ============================================================
   CTA
   ============================================================ */
.cta{padding-top:270px;text-align:center}
.cta__title{
  font-size:154px;line-height:.92;font-weight:800;letter-spacing:-.02em;text-transform:uppercase;
  transform:scaleX(1.12);
}
.cta .btn--pill{margin-top:46px}
.cta-portrait{margin:80px auto 0;width:444px;height:560px;border-radius:50%;overflow:hidden}
.cta-portrait img{
  width:100%;height:100%;object-fit:cover;object-position:center 22%;
  transform:scale(var(--zoom,1.04));transform-origin:center;will-change:transform;
}

/* ============================================================
   FOOTER
   ============================================================ */
.footer{padding:220px var(--gutter) 70px;text-align:center}
.footer__statement{
  max-width:760px;margin:0 auto;
  font-size:22px;line-height:1.4;font-weight:700;letter-spacing:.005em;text-transform:uppercase;
}
.footer__links{
  display:flex;justify-content:center;gap:40px;margin-top:46px;
  font-size:18px;font-weight:700;letter-spacing:.03em;text-transform:uppercase;
}
.footer__links a{display:inline-flex;align-items:center;gap:6px}
.footer__links .arrow{transition:transform .3s}
.footer__links a:hover .arrow{transform:translate(3px,-3px)}

/* SAY HELLO + Kontaktformular */
.sayhello{margin-top:260px;display:grid;grid-template-columns:1fr 1fr;gap:90px;align-items:start;text-align:left}
.footer__hello{font-size:56px;line-height:1;font-weight:800;letter-spacing:-.02em;text-transform:uppercase}
.sayhello__sub{margin-top:18px;font-size:22px;color:var(--muted);font-weight:500}
.sayhello__formlabel{margin-top:64px;font-size:15px;font-weight:700;letter-spacing:.04em;text-transform:uppercase}
.cform{margin-top:28px}
.cform__field{display:block;margin-bottom:22px}
.cform__field span{display:block;margin-bottom:8px;font-size:14px;color:var(--muted);font-weight:500}
.cform__field input,.cform__field textarea{
  width:100%;background:var(--card-gray);border:1px solid transparent;border-radius:12px;
  padding:18px 20px;font:inherit;font-size:16px;color:var(--ink);resize:none;
  transition:border-color .2s,background .2s;
}
.cform__field input::placeholder,.cform__field textarea::placeholder{color:var(--muted-2)}
.cform__field input:focus,.cform__field textarea:focus{outline:none;border-color:var(--ink);background:#fff}
.cform__submit{
  width:100%;margin-top:10px;background:var(--ink);color:#fff;border-radius:12px;
  padding:18px;font-size:16px;font-weight:700;cursor:pointer;transition:background .3s;
}
.cform__submit:hover{background:#000}
.sayhello__photo{border-radius:22px;overflow:hidden;aspect-ratio:654/735;width:100%;max-width:660px;margin-left:auto}
.sayhello__photo img{width:100%;height:100%;object-fit:cover}

/* Riesen-Brand */
.footer__brand{
  margin-top:200px;text-align:center;
  font-size:12.6vw;line-height:.9;font-weight:800;letter-spacing:-.03em;text-transform:uppercase;
}

/* Footer-Bar */
.footer__bar{
  margin-top:120px;display:grid;grid-template-columns:repeat(3,1fr);gap:40px;
  text-align:left;border-top:1px solid var(--line);padding-top:44px;
}
.footer__col{display:flex;flex-direction:column;gap:8px;font-size:16px;font-weight:600}
.footer__label{color:var(--muted-2);font-size:13px;letter-spacing:.05em;margin-bottom:4px;font-weight:600}
.footer__col a{transition:opacity .2s}
.footer__col a:hover{opacity:.55}
.footer__legal{
  margin-top:60px;display:grid;grid-template-columns:1fr auto 1fr;align-items:start;
  text-align:left;font-size:13px;letter-spacing:.03em;text-transform:uppercase;color:var(--muted);
}
.footer__legal-links{display:flex;flex-direction:column;gap:8px}
.footer__legal-links a:hover{color:var(--ink)}
.footer__copy{grid-column:2;text-align:center;white-space:nowrap;margin:0}

/* ============================================================
   CUSTOM CURSOR
   ============================================================ */
.cursor{
  position:fixed;top:0;left:0;z-index:9999;
  width:26px;height:26px;border-radius:50%;
  background:#fff;mix-blend-mode:difference;
  pointer-events:none;
  transform:translate(-50%,-50%);
  transition:width .25s ease,height .25s ease,opacity .25s ease;
  will-change:transform;
}
.cursor.grow{width:64px;height:64px}
.cursor.hide{opacity:0}
.has-cursor,.has-cursor a,.has-cursor button,.has-cursor .testimonials__track{cursor:none}

/* ============================================================
   REVEAL ANIMATIONS
   ============================================================ */
.reveal{opacity:0;transform:translateY(30px);transition:opacity .9s cubic-bezier(.2,.8,.2,1),transform .9s cubic-bezier(.2,.8,.2,1)}
.reveal.in{opacity:1;transform:none}
.reveal-img{overflow:hidden}
.reveal-img img{transform:scale(1.12);transition:transform 1.4s cubic-bezier(.2,.8,.2,1),clip-path 1.2s ease;clip-path:inset(0 0 100% 0)}
.reveal-img.in img{transform:scale(1);clip-path:inset(0 0 0 0)}
.reveal-lines .line span{display:block;transform:translateY(110%);transition:transform 1s cubic-bezier(.2,.8,.2,1)}
.reveal-lines.in .line span{transform:none}
.reveal-lines.in .line:nth-child(2) span{transition-delay:.08s}

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (max-width:1400px){
  .hero__title,.cta__title{font-size:7.6vw}
  .section-title,.featured .section-title,.traits .section-title{font-size:3vw}
  .testimonials .section-title{font-size:4.6vw}
  .motivation__title{font-size:3.6vw}
  .section-head{font-size:5.2vw}
}
@media (max-width:1024px){
  :root{--gutter:28px}
  .experience__grid{grid-template-columns:1fr;gap:24px}
  .experience__col{margin-left:0;max-width:760px}
  .motivation__grid{grid-template-columns:1fr;gap:24px}
  .section-head{font-size:7vw}
  .motivation__body{max-width:760px}
  .intro p{font-size:26px}
  .services__grid{grid-template-columns:repeat(2,1fr)}
  .card.span-2,.card.span-3{grid-column:span 1}
  .featured__grid{grid-template-columns:repeat(4,1fr)}
  .sky{height:52vw}.laugh{height:50vw}.leopard{height:54vw}
}
@media (max-width:680px){
  :root{--gutter:20px}
  .hero__title,.cta__title{font-size:12vw}
  .sayhello{grid-template-columns:1fr;gap:40px}
  .footer__hello{font-size:42px}
  .footer__bar{grid-template-columns:1fr;gap:28px}
  .footer__legal{grid-template-columns:1fr;gap:20px}
  .footer__copy{grid-column:1;text-align:left}
  .cta-portrait{width:72vw;height:90vw}
  .intro p{font-size:21px}
  .story p{font-size:19px}
  .lead p{font-size:20px}
  .services__grid{grid-template-columns:1fr}
  .featured__grid{grid-template-columns:repeat(2,1fr)}
  .portrait-oval{width:72vw;height:90vw}
  .section-head{font-size:11vw}
  .testi{flex-basis:80vw}
  .hero__meta{flex-direction:column;gap:8px;align-items:flex-start}
  .cursor{display:none}
  .has-cursor,.has-cursor a,.has-cursor button{cursor:auto}
}

@media (max-width:880px){
  .cardmodal__box{padding:48px 32px 52px}
  .cardmodal__grid{grid-template-columns:1fr;gap:34px}
  .cardmodal__title{font-size:30px}
  .modal-list li{font-size:18px;margin-bottom:22px}
  .card__view{display:none}
}

/* ---------- Reduced motion ---------- */
@media (prefers-reduced-motion:reduce){
  *{scroll-behavior:auto!important}
  .reveal,.reveal-img img,.reveal-lines .line span{transition:none!important;opacity:1!important;transform:none!important;clip-path:none!important}
  .cursor{display:none}
}
