/* V18 ortho-motion style.css — dark + electric orange + bold athletic */
:root{
  --ink:#0d0d10;
  --ink-2:#1a1a1f;
  --ink-3:#2a2a30;
  --orange:#ff6b1a;
  --orange-deep:#cc4d0a;
  --orange-soft:#ffe2d3;
  --orange-glow:rgba(255,107,26,.4);
  --grey:#8a8a92;
  --grey-soft:#1f1f24;
  --white:#fff;
  --rule:#2a2a30;
  --warn-red:#c0392b;
  --demo-red:#ff4848;
  --display:'Bebas Neue',sans-serif;
  --sans:'Inter','Noto Sans KR',sans-serif;
  --banner-h:0px;
  --med-banner-h:0px;
  --shadow:0 8px 30px rgba(0,0,0,.5);
  --shadow-deep:0 20px 60px rgba(255,107,26,.25);
}
*{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth}
body{font-family:var(--sans);background:var(--ink);color:var(--white);line-height:1.6;font-size:16px;-webkit-font-smoothing:antialiased}
body.has-banner{padding-top:calc(var(--banner-h) + var(--med-banner-h))}
body.drawer-open{overflow:hidden}
a{color:inherit;text-decoration:none}img{display:block;max-width:100%;height:auto}

.medical-warning-banner{position:fixed;top:0;left:0;right:0;background:var(--warn-red);color:#fff;font-size:11px;font-weight:700;padding:7px 18px;text-align:center;letter-spacing:.04em;z-index:201;line-height:1.4}
.demo-banner{position:fixed;top:var(--med-banner-h);left:0;right:0;background:var(--ink-2);color:var(--orange-soft);font-size:11px;font-weight:500;padding:7px 18px;text-align:center;letter-spacing:.04em;z-index:200;line-height:1.4;border-bottom:1px solid var(--orange)}

/* NAV — Heavy bold dark with orange accent + bar logo */
.nav-bar{position:fixed;top:calc(var(--med-banner-h) + var(--banner-h));left:0;right:0;display:flex;align-items:stretch;justify-content:space-between;background:var(--ink);border-bottom:2px solid var(--orange);z-index:100;padding:0}
.nav-brand{display:inline-flex;align-items:center;gap:10px;padding:14px 24px;font-family:var(--display);font-size:24px;font-weight:400;color:var(--white);letter-spacing:.04em;background:var(--orange);clip-path:polygon(0 0,100% 0,calc(100% - 14px) 100%,0 100%);padding-right:40px}
.brand-bar{width:4px;height:24px;background:var(--white);display:inline-block}
.brand-mark{color:var(--white)}
.brand-sub{font-family:var(--sans);font-size:12px;color:rgba(255,255,255,.85);font-weight:600;font-style:italic;margin-left:6px}
.nav-list{list-style:none;display:inline-flex;align-items:stretch;gap:0;flex:1;justify-content:center}
.nav-list li{display:flex;align-items:center;border-right:1px solid var(--ink-3)}
.nav-list li:first-child{border-left:1px solid var(--ink-3)}
.nav-list li a{display:inline-flex;align-items:center;gap:8px;font-family:var(--display);font-size:15px;font-weight:400;color:var(--white);padding:0 24px;letter-spacing:.06em;height:100%;transition:background .3s,color .3s;text-transform:uppercase}
.nav-list li a .num{font-family:var(--sans);font-size:10px;font-weight:700;color:var(--orange);background:rgba(255,107,26,.16);padding:3px 7px;border-radius:0;letter-spacing:.04em}
.nav-list li a:hover{background:var(--orange);color:var(--white)}
.nav-list li a:hover .num{background:rgba(0,0,0,.3);color:var(--white)}
.nav-actions{display:inline-flex;align-items:stretch}
.nav-tel{display:inline-flex;align-items:center;font-family:var(--display);font-size:18px;font-weight:400;color:var(--orange);padding:0 18px;letter-spacing:.04em;border-left:1px solid var(--ink-3)}
.nav-login{display:inline-flex;align-items:center;font-family:var(--display);font-size:14px;font-weight:400;color:var(--white);padding:0 14px;letter-spacing:.1em;border-left:1px solid var(--ink-3);text-transform:uppercase;transition:color .3s}
.nav-login:hover{color:var(--orange)}
.nav-signup{display:inline-flex;align-items:center;font-family:var(--display);font-size:14px;font-weight:400;color:var(--orange);padding:0 18px;letter-spacing:.1em;border-left:1px solid var(--ink-3);text-transform:uppercase;transition:background .3s}
.nav-signup:hover{background:var(--ink-3)}
.nav-cta{display:inline-flex;align-items:center;font-family:var(--display);font-size:16px;font-weight:400;color:var(--ink);background:var(--orange);padding:0 28px;letter-spacing:.06em;transition:background .3s;text-transform:uppercase;clip-path:polygon(14px 0,100% 0,100% 100%,0 100%)}
.nav-cta:hover{background:var(--white)}
.nav-burger{display:none;position:fixed;top:calc(var(--med-banner-h) + var(--banner-h) + 14px);right:16px;width:48px;height:48px;background:var(--orange);border:none;cursor:pointer;z-index:105;flex-direction:column;align-items:center;justify-content:center;gap:5px;box-shadow:var(--shadow-deep);clip-path:polygon(0 0,100% 0,100% calc(100% - 14px),calc(100% - 14px) 100%,0 100%)}
.burger-line{width:22px;height:2px;background:var(--white)}

.drawer{position:fixed;top:0;left:0;right:0;height:100vh;height:100dvh;background:var(--ink);color:var(--white);z-index:150;transform:translateY(-100%);transition:transform .5s cubic-bezier(.7,0,.3,1);overflow-y:auto;visibility:hidden}
.drawer.open{transform:translateY(0);visibility:visible}
.drawer-close{position:absolute;top:calc(var(--med-banner-h) + var(--banner-h) + 24px);right:24px;width:48px;height:48px;background:var(--orange);color:var(--white);border:none;font-size:28px;font-weight:300;cursor:pointer;border-radius:0;box-shadow:var(--shadow-deep);z-index:2;transition:transform .4s;clip-path:polygon(0 0,100% 0,100% calc(100% - 14px),calc(100% - 14px) 100%,0 100%)}
.drawer-close:hover{transform:rotate(90deg)}
.drawer-inner{padding:100px 36px 40px;max-width:480px}
.drawer-brand{font-family:var(--display);font-size:32px;font-weight:400;color:var(--white);margin-bottom:36px;letter-spacing:.04em}
.drawer-brand span{color:var(--orange);font-style:italic;font-size:14px}
.drawer-list{list-style:none;padding:0;margin:0 0 24px}
.drawer-list li{padding:14px 0;border-bottom:1px solid var(--ink-3)}
.drawer-list li a{display:flex;align-items:baseline;gap:14px;font-family:var(--display);font-size:20px;color:var(--white);font-weight:400;letter-spacing:.06em;text-transform:uppercase}
.drawer-list li a .num{font-family:var(--sans);font-size:11px;color:var(--orange);min-width:30px;font-weight:700}
.drawer-rule{border:none;height:1px;background:var(--orange);margin:24px 0;opacity:.3}
.drawer-foot{font-size:11px;color:rgba(255,255,255,.4)}

body.drawer-open .nav-bar,body.drawer-open .nav-burger{display:none!important}

section{padding:100px 36px}
.sec-head{max-width:1280px;margin:0 auto 48px}
.eyebrow{display:inline-block;font-family:var(--display);font-size:14px;font-weight:400;letter-spacing:.2em;color:var(--orange);margin-bottom:14px;padding:5px 14px;background:rgba(255,107,26,.12);border-left:3px solid var(--orange);text-transform:uppercase}
.eyebrow-light{color:var(--orange-soft)}
.sec-title{font-family:var(--display);font-size:clamp(40px,6vw,72px);font-weight:400;letter-spacing:.02em;line-height:1;color:var(--white);margin-bottom:8px;text-transform:uppercase}
.sec-title em{font-style:italic;color:var(--orange);font-weight:400}
.sec-sub{color:var(--grey);font-size:15px}
.demo-disclaimer{display:inline-block;padding:2px 8px;background:rgba(255,72,72,.12);color:var(--demo-red);font-size:10px;font-weight:700;letter-spacing:.12em;margin-left:6px}

.sec-hero{height:100vh;min-height:780px;padding:0;position:relative;background:var(--ink);color:var(--white);overflow:hidden;display:flex;align-items:center}
.hero-bg{position:absolute;inset:0;background-size:cover;background-position:center;filter:brightness(.45) contrast(1.15) saturate(.85)}
.hero-grad{position:absolute;inset:0;background:linear-gradient(135deg,rgba(13,13,16,.92) 0%,rgba(13,13,16,.4) 60%,rgba(255,107,26,.18) 100%)}
.hero-stripe{position:absolute;left:0;top:0;bottom:0;width:8px;background:var(--orange);z-index:2}
.hero-inner{position:relative;z-index:3;max-width:1280px;padding:0 36px;width:100%}
.hero-tag{font-family:var(--display);font-size:14px;font-weight:400;letter-spacing:.3em;color:var(--orange);margin-bottom:24px;padding:6px 16px;background:rgba(0,0,0,.6);display:inline-block;border-left:3px solid var(--orange);text-transform:uppercase}
.hero-title{font-family:var(--display);font-size:clamp(64px,11vw,156px);font-weight:400;line-height:.92;color:var(--white);margin-bottom:24px;letter-spacing:.02em;text-transform:uppercase}
.hero-title em{font-style:italic;color:var(--orange);font-weight:400;text-shadow:0 0 32px var(--orange-glow)}
.hero-sub{font-size:clamp(17px,2vw,22px);color:rgba(255,255,255,.85);margin-bottom:36px;max-width:680px;font-weight:500}
.hero-cta-row{display:inline-flex;gap:24px;align-items:center;flex-wrap:wrap}
.hero-cta{font-family:var(--display);font-size:18px;font-weight:400;background:var(--orange);color:var(--ink);padding:18px 36px;letter-spacing:.1em;text-transform:uppercase;transition:background .3s,transform .3s,box-shadow .3s;clip-path:polygon(14px 0,100% 0,calc(100% - 14px) 100%,0 100%)}
.hero-cta:hover{background:var(--white);transform:translateY(-2px);box-shadow:0 16px 32px var(--orange-glow)}
.hero-link{font-family:var(--display);font-size:14px;color:var(--orange);border-bottom:2px solid var(--orange);padding-bottom:4px;letter-spacing:.1em;text-transform:uppercase}

.sec-body{background:var(--ink-2)}
.body-grid{max-width:1280px;margin:0 auto;display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.body-card{background:var(--ink);border:1px solid var(--ink-3);padding:28px;cursor:pointer;transition:transform .3s,border-color .3s,box-shadow .3s;position:relative;overflow:hidden}
.body-card::before{content:'';position:absolute;top:0;left:0;width:0;height:4px;background:var(--orange);transition:width .4s}
.body-card:hover::before{width:100%}
.body-card:hover{transform:translateY(-4px);border-color:var(--orange);box-shadow:var(--shadow-deep)}
.body-card .num{font-family:var(--display);font-size:36px;color:var(--orange);font-weight:400;letter-spacing:.04em;margin-bottom:14px;display:block;line-height:1}
.body-card img{width:100%;height:120px;object-fit:cover;background:var(--ink-3);margin-bottom:18px}
.body-card .part{font-family:var(--display);font-size:22px;font-weight:400;color:var(--white);margin-bottom:6px;letter-spacing:.04em;text-transform:uppercase}
.body-card .desc{font-size:13px;color:var(--grey);margin-bottom:14px;line-height:1.55}
.body-card .issues{display:flex;flex-wrap:wrap;gap:6px}
.body-card .issue{display:inline-block;font-size:10px;font-weight:700;letter-spacing:.06em;background:var(--ink-3);color:var(--orange-soft);padding:4px 10px}

.sec-rehab{background:var(--ink)}
.rehab-timeline{max-width:1080px;margin:0 auto;list-style:none;padding:0;display:grid;grid-template-columns:repeat(5,1fr);gap:0;position:relative}
.rehab-step{background:var(--ink-2);border:1px solid var(--ink-3);padding:24px 20px;text-align:center;transition:transform .3s,border-color .3s,background .3s;position:relative}
.rehab-step::after{content:'→';position:absolute;right:-14px;top:50%;transform:translateY(-50%);background:var(--orange);color:var(--ink);width:28px;height:28px;display:flex;align-items:center;justify-content:center;font-family:var(--display);font-weight:400;z-index:2;font-size:18px;clip-path:polygon(0 0,100% 50%,0 100%)}
.rehab-step:last-child::after{display:none}
.rehab-step:hover{background:var(--ink);border-color:var(--orange);transform:translateY(-4px);z-index:1}
.rehab-step img{width:100%;height:100px;object-fit:cover;background:var(--ink-3);margin-bottom:14px;filter:grayscale(.3)}
.rehab-step .roman{font-family:var(--display);font-size:24px;color:var(--orange);font-weight:400;display:block;margin-bottom:8px;letter-spacing:.04em}
.rehab-step .phase{font-family:var(--display);font-size:14px;font-weight:400;color:var(--white);margin-bottom:8px;letter-spacing:.06em;text-transform:uppercase}
.rehab-step .goal{font-size:12px;color:var(--orange-soft);margin-bottom:6px;font-weight:600}
.rehab-step .treat{font-size:11px;color:var(--grey);line-height:1.5}

.sec-video{background:var(--ink-2)}
.video-grid{max-width:1280px;margin:0 auto;display:grid;grid-template-columns:repeat(4,1fr);gap:14px}
.video-card{background:var(--ink);border:1px solid var(--ink-3);overflow:hidden;cursor:pointer;transition:transform .3s,border-color .3s,box-shadow .3s;position:relative}
.video-card:hover{transform:translateY(-4px);border-color:var(--orange);box-shadow:var(--shadow-deep)}
.video-card .thumb{position:relative;height:160px;overflow:hidden}
.video-card img{width:100%;height:100%;object-fit:cover;background:var(--ink-3);transition:transform .4s}
.video-card:hover img{transform:scale(1.05)}
.video-card .play{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:50px;height:50px;background:var(--orange);color:var(--ink);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:18px;font-weight:700;box-shadow:0 8px 20px rgba(0,0,0,.6)}
.video-card .dur{position:absolute;right:8px;bottom:8px;background:rgba(0,0,0,.85);color:var(--orange);font-family:var(--display);font-size:13px;padding:3px 8px;letter-spacing:.04em}
.video-card .body{padding:18px}
.video-card .cat{font-family:var(--display);font-size:11px;color:var(--orange);font-weight:400;letter-spacing:.18em;margin-bottom:8px;text-transform:uppercase}
.video-card .ttl{font-size:14px;font-weight:700;color:var(--white);line-height:1.4}

.sec-treat{background:var(--ink)}
.treat-grid{max-width:1280px;margin:0 auto;display:grid;grid-template-columns:repeat(4,1fr);gap:14px}
.treat-card{background:var(--ink-2);border:1px solid var(--ink-3);overflow:hidden;transition:transform .3s,border-color .3s}
.treat-card:hover{transform:translateY(-4px);border-color:var(--orange)}
.treat-card img{width:100%;height:160px;object-fit:cover;background:var(--ink-3)}
.treat-card .body{padding:22px}
.treat-card .ttl{font-family:var(--display);font-size:20px;font-weight:400;color:var(--white);margin-bottom:8px;letter-spacing:.04em;text-transform:uppercase}
.treat-card .desc{font-size:13px;color:var(--grey);line-height:1.6}

.sec-doctors{background:var(--ink-2)}
.doctors-grid{max-width:1080px;margin:0 auto;display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.doc-card{background:var(--ink);border:1px solid var(--ink-3);overflow:hidden;text-align:center;transition:transform .3s,border-color .3s,box-shadow .3s}
.doc-card:hover{transform:translateY(-4px);border-color:var(--orange);box-shadow:var(--shadow-deep)}
.doc-card img{width:100%;height:240px;object-fit:cover;background:var(--ink-3);filter:grayscale(.3) contrast(1.05)}
.doc-card .body{padding:22px}
.doc-card .name{font-family:var(--display);font-size:24px;font-weight:400;color:var(--white);margin-bottom:4px;letter-spacing:.04em;text-transform:uppercase}
.doc-card .role{font-family:var(--display);font-size:11px;font-weight:400;letter-spacing:.18em;color:var(--orange);margin-bottom:14px;text-transform:uppercase}
.doc-card .cred{font-size:13px;color:var(--grey);margin-bottom:10px;line-height:1.55}
.doc-card .spec{font-size:12px;color:var(--orange-soft);font-weight:700;border-top:1px solid var(--ink-3);padding-top:10px;margin-top:10px}

.sec-before{background:var(--ink)}
.before-grid{max-width:1280px;margin:0 auto;display:grid;grid-template-columns:repeat(2,1fr);gap:18px}
.before-card{display:grid;grid-template-columns:160px 1fr;gap:18px;background:var(--ink-2);padding:18px;border-left:4px solid var(--orange);transition:transform .3s,box-shadow .3s}
.before-card:hover{transform:translateY(-3px);box-shadow:var(--shadow)}
.before-card img{width:100%;height:120px;object-fit:cover;background:var(--ink-3);filter:grayscale(.4)}
.before-card .tag{display:inline-block;font-family:var(--display);font-size:11px;color:var(--ink);background:var(--orange);padding:3px 10px;letter-spacing:.06em;margin-bottom:10px;text-transform:uppercase}
.before-card .title{font-size:15px;font-weight:700;color:var(--white);margin-bottom:8px;line-height:1.4}
.before-card .anon{font-size:11px;color:var(--demo-red);font-style:italic}
.before-foot{max-width:1280px;margin:36px auto 0;font-size:13px;color:var(--demo-red);text-align:center;padding:14px;background:rgba(255,72,72,.05);border:1px dashed var(--demo-red);font-weight:600}

.sec-hours{background:var(--ink-2)}
.hours-card{max-width:880px;margin:0 auto;background:var(--ink);border:1px solid var(--orange);padding:36px;box-shadow:var(--shadow)}
.hours-table{width:100%;border-collapse:collapse}
.hours-table tr{border-bottom:1px solid var(--ink-3)}
.hours-table tr:last-child{border-bottom:none}
.hours-table th,.hours-table td{padding:14px 18px;text-align:left;font-size:14px;color:var(--white);font-weight:500}
.hours-table th{background:var(--orange);color:var(--ink);font-family:var(--display);font-weight:400;font-size:12px;letter-spacing:.18em;text-transform:uppercase}
.hours-table td.late{color:var(--orange);font-weight:700}
.hours-table tr.off td{color:var(--demo-red);font-weight:500}
.hours-note{margin-top:20px;font-size:12px;color:var(--grey);text-align:center}

.sec-stats{background:var(--orange);color:var(--ink);padding:80px 36px}
.stats-inner{max-width:1080px;margin:0 auto;display:grid;grid-template-columns:repeat(4,1fr);gap:36px;text-align:center}
.stat-cell .n{font-family:var(--display);font-size:80px;font-weight:400;color:var(--ink);line-height:1;margin-bottom:14px;letter-spacing:.02em}
.stat-cell .l{font-family:var(--display);font-size:13px;color:rgba(13,13,16,.85);letter-spacing:.18em;text-transform:uppercase;font-weight:400}
.stats-foot{max-width:1080px;margin:24px auto 0;text-align:center;font-size:11px;color:rgba(13,13,16,.7)}

.sec-cta{background:var(--ink);color:var(--white);padding:100px 36px}
.cta-inner{max-width:720px;margin:0 auto}
.sec-cta .sec-title{color:var(--white)}
.cta-form{display:flex;flex-direction:column;gap:14px;background:var(--ink-2);padding:36px;border:1px solid var(--orange);margin-top:24px}
.cta-form label{font-family:var(--display);font-size:12px;color:var(--orange);display:flex;flex-direction:column;gap:6px;letter-spacing:.16em;font-weight:400;text-transform:uppercase}
.cta-form input,.cta-form select,.cta-form textarea{font-family:var(--sans);font-size:16px;padding:14px;background:var(--ink);color:var(--white);border:1px solid var(--ink-3);width:100%;font-weight:500;border-radius:0}
.cta-form input:focus,.cta-form select:focus,.cta-form textarea:focus{outline:none;border-color:var(--orange)}
.cta-form textarea{resize:vertical;min-height:100px}
.cta-submit{font-family:var(--display);font-size:18px;font-weight:400;background:var(--orange);color:var(--ink);padding:18px 36px;border:none;cursor:pointer;margin-top:12px;letter-spacing:.1em;text-transform:uppercase;transition:background .3s,transform .3s;clip-path:polygon(14px 0,100% 0,calc(100% - 14px) 100%,0 100%)}
.cta-submit:hover{background:var(--white);transform:translateY(-2px)}
.cta-foot{margin-top:14px;font-size:11px;color:var(--demo-red);text-align:center}

.footer{background:#06060a;color:var(--grey);padding:50px 36px 24px;border-top:3px solid var(--orange);font-size:13px}
.footer-inner{max-width:1280px;margin:0 auto;display:grid;grid-template-columns:1fr 1fr;gap:36px;padding-bottom:30px;border-bottom:1px solid var(--ink-3)}
.footer-brand{font-family:var(--display);font-size:32px;font-weight:400;color:var(--white);margin-bottom:14px;letter-spacing:.04em}
.footer-brand span{color:var(--orange);font-style:italic;font-size:18px}
.footer-tag{font-family:var(--display);color:var(--orange);font-size:14px;margin-bottom:20px;letter-spacing:.18em;text-transform:uppercase}
.footer-sns{display:flex;gap:18px;margin-top:14px}
.footer-sns a{font-family:var(--display);color:var(--orange);font-size:13px;text-transform:uppercase;letter-spacing:.06em}
.footer-copy{margin-top:20px;font-size:11px;color:var(--grey);text-align:center;font-style:italic}

@media (max-width:1024px){
  .body-grid,.video-grid,.treat-grid{grid-template-columns:repeat(2,1fr)}
  .doctors-grid{grid-template-columns:repeat(2,1fr)}
  .stats-inner{grid-template-columns:repeat(2,1fr);gap:24px}
  .rehab-timeline{grid-template-columns:repeat(3,1fr)}
  .rehab-step:nth-child(3n)::after{display:none}
  .before-grid{grid-template-columns:1fr}
}
@media (max-width:768px){
  .nav-bar{display:none}.nav-burger{display:inline-flex}
  section{padding:60px 22px}
  .body-grid,.video-grid,.treat-grid,.doctors-grid{grid-template-columns:1fr}
  .stats-inner{grid-template-columns:repeat(2,1fr)}.stat-cell .n{font-size:54px}
  .rehab-timeline{grid-template-columns:1fr}.rehab-step::after{display:none}
  .before-card{grid-template-columns:1fr}
  .footer-inner{grid-template-columns:1fr}
}

/* 1D 인터랙션 추가 (universal patch 2026-04-28) */
.reveal-init{opacity:0; transform:translateY(20px); transition:opacity .8s ease, transform .8s ease}
.reveal-in{opacity:1 !important; transform:none !important}
.hero-bg{transition:transform .4s ease-out}
@keyframes pulse-anim{0%,100%{opacity:.85}50%{opacity:1}}
[class*="brand-stamp"], [class*="brand-glyph"], [class*="brand-orb"], [class*="brand-tag"], [class*="brand-frame"], [class*="brand-icon"]{animation:pulse-anim 3s ease-in-out infinite; display:inline-block}

/* 1D 강화 — 시각적 cursor follower + magnetic CTA + card tilt (universal patch v2) */
.cursor-follower{position:fixed; top:0; left:0; width:32px; height:32px; border:2px solid currentColor; border-radius:50%; pointer-events:none; z-index:9999; transform:translate(-50%,-50%); transition:transform .15s ease-out, width .25s, height .25s, background .25s; mix-blend-mode:difference; opacity:.85}
.cursor-follower.cursor-grow{width:60px; height:60px; background:rgba(255,255,255,.1)}
.cursor-follower.cursor-shrink{width:8px; height:8px}
.nav-cta, .nav-signup, [class*="-form-submit"], [class*="-cta"] a{transition:transform .25s cubic-bezier(.34,1.56,.64,1), box-shadow .3s !important}
[class*="-card"]{transition:transform .35s cubic-bezier(.2,.85,.4,1.275), box-shadow .35s, border-color .25s !important}
@media (max-width:768px){.cursor-follower{display:none !important}}

/* 1D-2 cursor diversify — indigo arrow */
.cursor-follower{border-color:#4a5fbf; mix-blend-mode:normal; box-shadow:0 0 16px rgba(74,95,191,.4)}
.cursor-follower::before{content:"→"; position:absolute; top:50%; left:50%; transform:translate(-50%,-50%); color:#4a5fbf; font-size:14px; font-weight:700}

/* 1D-4 mobile interaction — touch ripple + particle (universal) */
@media (max-width:768px){
  .touch-ripple{position:fixed; pointer-events:none; z-index:9998; border-radius:50%; transform:translate(-50%,-50%); animation:touch-ripple-anim .6s ease-out forwards; mix-blend-mode:multiply}
  @keyframes touch-ripple-anim{
    0%{width:10px; height:10px; opacity:.7; border:2px solid currentColor; background:transparent}
    100%{width:80px; height:80px; opacity:0; border:1px solid currentColor; background:transparent}
  }
  .touch-particle{position:fixed; pointer-events:none; z-index:9998; transform:translate(-50%,-50%); transition:all 1.2s ease-out; opacity:.9; font-size:14px}
  /* iOS smooth scroll + active feedback */
  a, button, [class*="-card"]{-webkit-tap-highlight-color:transparent}
  a:active, button:active, [class*="-card"]:active{transform:scale(.97); transition:transform .1s}
}


/* ===========================================
   RETROFIT v1.27 — motionsites integration
   slug: ortho-motion
   effects: N, Y
   =========================================== */
/* === retrofit v1.27 motionsites liquid-glass (MIT) === */
.btn, .cta-btn, .nav-cta, [class*="-btn"], [class*="-cta"], button[type="submit"] {
  position: relative;
  overflow: hidden;
}
.btn::before, .cta-btn::before, .nav-cta::before {
  content: ''; position: absolute; inset: 0; pointer-events: none;
  background: linear-gradient(180deg, rgba(255,255,255,0.18), rgba(255,255,255,0) 50%, rgba(255,255,255,0.12));
  opacity: 0.7; border-radius: inherit;
  transition: opacity 0.3s;
}
.btn:hover::before, .cta-btn:hover::before, .nav-cta:hover::before { opacity: 1; }/* === retrofit v1.27 motionsites glow-pulse (MIT) === */
@media (prefers-reduced-motion: no-preference) {
  .cta-btn, [class*="-cta"]:not([class*="cta-block"]) {
    position: relative;
  }
  .cta-btn::after, [class*="-cta"]:not([class*="cta-block"])::after {
    content: ''; position: absolute; inset: -8px;
    border-radius: inherit;
    background: var(--accent, #C4A062);
    filter: blur(20px); opacity: 0.3; z-index: -1;
    animation: rt-glow-pulse 3s ease-in-out infinite;
  }
  @keyframes rt-glow-pulse { 0%,100% { opacity: 0.25; transform: scale(1); } 50% { opacity: 0.5; transform: scale(1.05); } }
}