:root{
  --bg:#fff;
  --soft:#fbf8ff;
  --soft-2:#f3ebff;
  --ink:#1d0d4d;
  --muted:#635b7d;
  --line:#eadff8;
  --violet:#7235dc;
  --violet-2:#8f55ff;
  --lavender:#efe3ff;
  --yellow:#ffb423;
  --yellow-soft:#fff0cf;
  --radius:18px;
  --radius-sm:10px;
  --shadow:0 18px 45px rgba(55,20,110,.12);
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;background:var(--bg);color:var(--ink);font-family:Inter,system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif;line-height:1.65}
a{color:inherit;text-decoration:none}
img{max-width:100%;height:auto;display:block}
.container{width:min(1180px,calc(100% - 40px));margin:auto}
.screen-reader-text,.skip-link{position:absolute;left:-9999px}
.skip-link:focus{left:16px;top:16px;background:#fff;padding:10px;z-index:100}
.site-header{position:sticky;top:0;z-index:20;background:rgba(255,255,255,.94);backdrop-filter:blur(18px);box-shadow:0 10px 30px rgba(62,33,112,.08)}
.header-inner{display:flex;align-items:center;gap:30px;min-height:90px}
.brand{display:inline-flex;align-items:center;gap:12px;font-weight:900;color:var(--ink)}
.custom-logo{max-height:58px;width:auto}
.logo-mark{position:relative;display:inline-block;width:46px;height:46px;border-radius:50%;background:linear-gradient(145deg,#c874ff,#7b38df);box-shadow:inset -4px -5px 0 rgba(45,12,100,.22)}
.logo-mark:before{content:"";position:absolute;left:9px;right:9px;bottom:-8px;height:18px;background:radial-gradient(circle at 4px 8px,#9b58ec 0 6px,transparent 7px),radial-gradient(circle at 14px 8px,#9b58ec 0 6px,transparent 7px),radial-gradient(circle at 24px 8px,#9b58ec 0 6px,transparent 7px)}
.logo-mark:after{content:"";position:absolute;left:12px;top:17px;width:6px;height:9px;border-radius:50%;background:#1d0d4d;box-shadow:15px 0 0 #1d0d4d}
.logo-text{font-size:2rem;line-height:.9;letter-spacing:0}
.logo-text span{color:var(--yellow)}
.logo-text small{display:block;margin-top:8px;font-size:.67rem;letter-spacing:.12em;text-transform:uppercase;color:#89809f}
.main-nav{margin-left:auto}
.main-nav ul{display:flex;align-items:center;gap:34px;list-style:none;margin:0;padding:0}
.main-nav a{position:relative;font-weight:800;font-size:.95rem;color:var(--ink)}
.main-nav a:hover,.main-nav .current-menu-item>a{color:var(--violet)}
.main-nav a:after{content:"";position:absolute;left:0;right:0;bottom:-17px;height:3px;border-radius:3px;background:var(--violet);transform:scaleX(0);transition:.2s}
.main-nav a:hover:after,.main-nav .current-menu-item>a:after{transform:scaleX(1)}
.menu-toggle{display:none;width:46px;height:42px;border:1px solid var(--line);background:#fff;border-radius:12px}
.menu-toggle span:not(.screen-reader-text){display:block;width:20px;height:2px;margin:4px auto;background:var(--ink);border-radius:2px}
.btn{display:inline-flex;align-items:center;justify-content:center;gap:12px;border:0;border-radius:12px;padding:15px 24px;font-weight:900;line-height:1.1;cursor:pointer;box-shadow:0 10px 22px rgba(114,53,220,.16)}
.btn.primary,.header-cta{background:linear-gradient(135deg,var(--violet),#6f2edc);color:#fff}
.btn.ghost{background:#fff;color:var(--ink);border:1px solid var(--line)}
.btn.light{background:#fff;color:var(--ink)}
.header-cta{margin-left:10px;white-space:nowrap}
.hero{position:relative;overflow:hidden;padding:72px 0 64px;background:linear-gradient(110deg,#fff 0%,#fff 48%,#ffe9ac 100%)}
.hero:before{content:"";position:absolute;inset:0;background:radial-gradient(circle at 66% 12%,rgba(151,83,255,.14),transparent 24%),radial-gradient(circle at 90% 78%,rgba(255,180,35,.38),transparent 30%);pointer-events:none}
.hero-grid{position:relative;display:grid;grid-template-columns:1fr 1fr;align-items:center;gap:54px}
.eyebrow{margin:0 0 12px;text-transform:uppercase;letter-spacing:.05em;font-size:.83rem;font-weight:950;color:var(--violet)}
.badge{display:inline-block;padding:5px 12px;border-radius:999px;background:var(--violet-2);color:#fff}
h1,h2,h3,p{overflow-wrap:anywhere}
.hero h1,.single-hero h1,.page-content h1{max-width:680px;margin:0 0 18px;font-size:clamp(2.8rem,5.5vw,4.8rem);line-height:1.05;letter-spacing:0;color:var(--ink)}
.hero h1 span,.section-head h2 span,.services-section h2 span,.blog-section h2 span,.cta-band h2 span{color:var(--violet)}
.hero-text{max-width:560px;margin:0 0 26px;font-size:1.2rem;color:#23174f}
.hero-points{display:flex;gap:26px;flex-wrap:wrap;margin:0 0 28px;font-weight:900}
.hero-points span{position:relative;padding-left:26px}
.hero-points span:before{content:"";position:absolute;left:0;top:.35em;width:16px;height:16px;border-radius:50%;background:var(--yellow);box-shadow:inset 0 0 0 5px #fff2c6}
.hero-actions{display:flex;gap:16px;flex-wrap:wrap}
.hero-art{position:relative;min-height:430px;display:grid;place-items:center}
.speech{position:absolute;right:0;top:80px;max-width:220px;padding:26px 28px;border:3px solid #cda8ff;border-radius:38px;background:#fff;color:#3b1888;font-size:1.25rem;font-weight:950;line-height:1.35;text-align:center}
.speech span{display:block;color:var(--yellow);font-size:1.8rem;margin-top:8px}
.speech span:before{content:"";display:inline-block;width:18px;height:18px;background:var(--yellow);transform:rotate(45deg);border-radius:5px}
.mascot{position:relative;width:210px;height:210px;border-radius:50% 50% 44% 44%;background:linear-gradient(145deg,#c46cff 0%,#8e45e8 65%,#7130cf 100%);border:4px solid #2a126b;box-shadow:inset -13px -15px 0 rgba(45,12,100,.18),0 28px 22px rgba(61,25,120,.14)}
.mascot:before{content:"";position:absolute;left:68px;top:88px;width:20px;height:34px;border-radius:50%;background:#190c4c;box-shadow:58px 0 0 #190c4c}
.mascot:after{content:"";position:absolute;left:98px;top:122px;width:42px;height:24px;border-bottom:5px solid #2a126b;border-radius:0 0 40px 40px}
.mascot .bulb{position:absolute;right:-6px;top:-74px;width:48px;height:62px;border-radius:50% 50% 44% 44%;background:#ffd35f;border:4px solid #2a126b;box-shadow:0 0 0 10px rgba(255,180,35,.2)}
.mascot .bulb:after{content:"";position:absolute;left:13px;bottom:-16px;width:22px;height:18px;border-radius:5px;background:#2a126b}
.mascot-xl{width:260px;height:260px}
.mascot-md{width:132px;height:132px;border-width:3px}
.mascot-sm{width:104px;height:104px;border-width:3px}
.mascot-xs{width:78px;height:78px;border-width:2px}
.mascot:where(.mascot-xl):before{left:76px;top:105px}
.mascot:where(.mascot-xl):after{left:118px;top:145px}
.mascot-md:before{left:39px;top:52px;width:12px;height:20px;box-shadow:36px 0 0 #190c4c}
.mascot-md:after{left:61px;top:76px;width:26px;height:16px;border-bottom-width:3px}
.mascot-sm:before{left:30px;top:40px;width:10px;height:17px;box-shadow:28px 0 0 #190c4c}
.mascot-sm:after{left:47px;top:59px;width:21px;height:12px;border-bottom-width:3px}
.mascot-xs:before{left:22px;top:30px;width:8px;height:13px;box-shadow:21px 0 0 #190c4c}
.mascot-xs:after{left:36px;top:44px;width:16px;height:9px;border-bottom-width:2px}
.mascot-xl:after,.mascot-md:after,.mascot-sm:after,.mascot-xs:after{background:transparent}
.mascot:empty{display:block}
.mascot.is-waving{transform:rotate(-4deg)}
.services-section{padding:62px 0 36px;text-align:center}
.center{text-align:center}
.services-section h2,.section-head h2{margin:0;font-size:clamp(2rem,3.8vw,3rem);line-height:1.08}
.service-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;margin-top:44px;text-align:center}
.service-grid article,.post-card,.project-card,.contact-form-card,.summary-card,.related-card,.contact-cards article{background:#fff;border:1px solid var(--line);border-radius:var(--radius-sm);box-shadow:0 12px 30px rgba(42,18,107,.06)}
.service-grid article{padding:34px 22px}
.service-grid i,.help-card i,.contact-cards i{display:grid;place-items:center;width:70px;height:70px;margin:0 auto 20px;border-radius:50%;background:var(--soft-2);color:var(--violet);font-style:normal;font-weight:950;font-size:1.1rem}
.service-grid h3,.project-card h3,.post-card h2{margin:0 0 10px;font-size:1.1rem;line-height:1.25}
.service-grid p,.post-card p,.project-card p{margin:0 0 18px;color:#35295d;font-size:.95rem}
.service-grid a,.read-more,.link-arrow{font-weight:950;color:var(--violet)}
.projects-band{position:relative;margin-top:28px;padding:42px 0 54px;background:#f7f1ff;overflow:hidden}
.section-head{display:flex;align-items:flex-start;justify-content:space-between;gap:24px;margin-bottom:28px}
.project-grid,.post-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.post-card{overflow:hidden}
.post-thumb img,.thumb-placeholder,.fake-thumb{width:100%;aspect-ratio:1.45/1;object-fit:cover;background:linear-gradient(135deg,#fff0d3,#d9c2ff);display:grid;place-items:center;color:var(--violet);font-weight:950}
.thumb-placeholder:before{content:"Orane Lab"}
.post-card-body,.project-card>div:not(.fake-thumb){padding:22px}
.meta-row{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:14px;font-size:.8rem;color:#766b93}
.pill{display:inline-flex;padding:5px 9px;border-radius:999px;background:#f2e6ff;color:var(--violet);font-weight:950;text-transform:uppercase;font-size:.68rem}
.blog-section{padding:54px 0}
.post-grid.compact .post-card{box-shadow:0 12px 30px rgba(42,18,107,.07)}
.cta-band{position:relative;display:flex;align-items:center;justify-content:space-between;gap:30px;margin-top:28px;margin-bottom:-52px;padding:34px 48px;border-radius:14px;background:linear-gradient(105deg,#7132dd 0%,#9d64d9 48%,#ffb423 100%);color:#fff;overflow:hidden;z-index:2}
.cta-band h2{margin:0;font-size:2rem;line-height:1.15}
.cta-band p{margin:8px 0 0;font-size:1.1rem}
.cta-band .mascot{flex:0 0 auto}
.cta-band.slim{margin-bottom:34px;background:linear-gradient(105deg,#e9d6ff,#ffe5a6);color:var(--ink)}
.site-footer{padding:96px 0 28px;background:#1a123d;color:#fff}
.footer-grid{display:grid;grid-template-columns:1.35fr .75fr .95fr .85fr 1.35fr;gap:34px}
.site-footer .brand{color:#fff}
.site-footer h2{margin:0 0 16px;font-size:.95rem}
.site-footer p,.site-footer li,.footer-bottom{color:#d8d1ed;font-size:.92rem}
.site-footer ul{list-style:none;margin:0;padding:0;display:grid;gap:8px}
.site-footer .menu a{color:#d8d1ed}
.socials{display:flex;gap:10px;margin-top:20px}
.socials a{display:grid;place-items:center;width:34px;height:34px;border-radius:50%;background:#2d2258;color:#fff;font-weight:900}
.newsletter form{display:flex;margin-top:18px;background:#fff;border-radius:8px;overflow:hidden}
.newsletter input{min-width:0;flex:1;border:0;padding:14px}
.newsletter button{width:50px;border:0;background:var(--violet);color:#fff;font-weight:950}
.footer-bottom{display:flex;justify-content:space-between;gap:20px;margin-top:42px;padding-top:24px;border-top:1px solid rgba(255,255,255,.12)}
.footer-bottom a{margin-left:20px}
.breadcrumbs{display:flex;gap:12px;flex-wrap:wrap;margin-bottom:42px;color:#5d5279;font-size:.9rem}
.single-hero{padding:54px 0 38px;background:linear-gradient(110deg,#fff 0%,#fff 55%,#fbf3ff 100%)}
.single-hero-grid{display:grid;grid-template-columns:1.12fr .88fr;align-items:center;gap:42px}
.single-hero h1{font-size:clamp(2.6rem,4.8vw,4.2rem)}
.author-row{display:flex;align-items:center;gap:14px;margin-top:30px}
.avatar{display:grid;place-items:center;width:56px;height:56px;border-radius:50%;background:linear-gradient(135deg,#ffe5c0,#c69b7d);color:#fff;font-weight:950}
.author-row span{color:#6f6686}
.article-shell{display:grid;grid-template-columns:minmax(0,1fr) 330px;gap:58px;padding:42px 0 52px;border-top:1px solid #efe8f7}
.article-content{font-size:1.08rem;color:#160d3e}
.article-content>*:first-child{margin-top:0}
.article-content h2{position:relative;margin:2em 0 .7em;padding-left:48px;font-size:2rem;line-height:1.15;color:var(--ink)}
.article-content h2:before{content:"";position:absolute;left:0;top:.05em;width:34px;height:34px;border-radius:50%;background:var(--violet)}
.article-content ul{padding-left:1.2em}
.article-content li::marker{color:var(--violet)}
.article-content a{text-decoration:underline;text-decoration-color:var(--violet)}
.article-content blockquote{margin:28px 0;padding:22px 26px;border-radius:12px;background:#f4eaff;border-left:6px solid var(--violet);font-weight:800}
.article-helper{display:flex;align-items:center;gap:24px;margin-top:34px;padding:24px 30px;border-radius:12px;background:#f1e6ff}
.article-sidebar{display:grid;gap:28px;align-self:start;position:sticky;top:118px}
.summary-card,.related-card{padding:28px}
.summary-card h2,.related-card h2,.side-cta h2{margin:0 0 18px;font-size:1.2rem}
.summary-card ol{display:grid;gap:14px;margin:0;padding-left:22px;color:#4a4165}
.summary-card a{color:var(--violet);font-weight:900}
.side-cta{padding:28px;border-radius:14px;background:linear-gradient(145deg,#f3e6ff,#fff8eb)}
.side-cta .mascot{margin:12px auto}
.related-item{display:grid;grid-template-columns:68px 1fr;gap:14px;align-items:center;margin-bottom:18px}
.related-item img,.related-item span{width:68px;height:58px;border-radius:8px;object-fit:cover;background:linear-gradient(135deg,#dbe9ff,#fff0c9)}
.page-content{padding:62px 0;max-width:860px}
.page-body{overflow:hidden}
.project-facts{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:34px}
.project-facts p{margin:0;padding:18px;border:1px solid var(--line);border-radius:var(--radius-sm);background:#fff;box-shadow:0 12px 30px rgba(42,18,107,.05)}
.project-facts span{display:block;margin-bottom:6px;color:var(--muted);font-size:.78rem;text-transform:uppercase;font-weight:900}
.project-facts strong{display:block;color:var(--ink);line-height:1.25}
.about-hero{background:linear-gradient(110deg,#fff 0%,#fff 52%,#fff0cf 100%)}
.about-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:34px;align-items:start;padding:56px 0 26px}
.about-grid h2{margin:0 0 18px;font-size:clamp(2rem,3.6vw,3rem);line-height:1.08}
.about-grid p{font-size:1.08rem;color:#302653}
.about-card{padding:32px;border:1px solid var(--line);border-radius:var(--radius-sm);background:linear-gradient(145deg,#f5ecff,#fff9ec);box-shadow:0 12px 30px rgba(42,18,107,.06)}
.about-card h3{margin:0 0 18px;font-size:1.45rem}
.about-card ul{display:grid;gap:14px;margin:0;padding-left:1.2em}
.about-card li::marker{color:var(--violet)}
.about-values{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;padding:18px 0 36px}
.about-values article{padding:28px;border:1px solid var(--line);border-radius:var(--radius-sm);background:#fff;box-shadow:0 12px 30px rgba(42,18,107,.06)}
.about-values i{display:grid;place-items:center;width:54px;height:54px;margin-bottom:18px;border-radius:50%;background:var(--soft-2);color:var(--violet);font-style:normal;font-weight:950}
.about-values h3{margin:0 0 8px;font-size:1.2rem}
.about-values p{margin:0;color:#302653}
.contact-hero{background:linear-gradient(110deg,#fff 0%,#fff 55%,#fff7e3 100%)}
.contact-grid{display:grid;grid-template-columns:1.1fr .9fr;gap:30px;padding:34px 0 28px}
.contact-form-card{padding:36px}
.contact-form-card h2,.help-card h2{margin:0 0 22px;font-size:1.75rem}
.contact-form{display:grid;grid-template-columns:1fr 1fr;gap:18px}
.contact-form label{display:grid}
.contact-form label span{position:absolute;left:-9999px}
.contact-form input,.contact-form textarea{width:100%;border:1px solid #dfd1f1;border-radius:10px;padding:17px 18px;font:inherit;color:var(--ink);background:#fff}
.contact-form textarea{resize:vertical}
.contact-form .wide{grid-column:1/-1}
.contact-form .accept{position:relative;display:flex;gap:10px;align-items:center;color:#746a8d;font-size:.9rem}
.contact-form .accept span{position:static}
.contact-form .accept input{width:20px;height:20px;padding:0}
.contact-form button{width:100%;font-size:1rem}
.help-card{padding:36px;border-radius:18px;background:linear-gradient(145deg,#f3e8ff,#fff0cc)}
.help-card ul{list-style:none;margin:0;padding:0;display:grid;gap:22px}
.help-card li{display:grid;grid-template-columns:64px 1fr;column-gap:18px;align-items:center}
.help-card i{grid-row:1/3;width:56px;height:56px;margin:0;background:#fff}
.help-card strong{font-size:1.05rem}
.help-card span{color:#302653}
.help-note{display:flex;align-items:center;gap:22px;margin:28px -18px -18px;padding:22px;border-radius:14px;background:rgba(255,255,255,.46)}
.help-note strong{display:inline-block;margin-top:8px;color:var(--violet);font-size:1.25rem;font-style:italic}
.contact-cards{display:grid;grid-template-columns:repeat(3,1fr);gap:28px;margin-bottom:34px}
.contact-cards article{display:grid;grid-template-columns:72px 1fr;align-items:center;gap:16px;padding:24px}
.contact-cards i{width:56px;height:56px;margin:0;background:#f1e3ff}
.contact-cards h3,.contact-cards p{margin:0}
.contact-cards span{color:#6e6387}
.cta-band.contact{margin-bottom:-52px}
.search-form{display:flex;background:#fff;border:1px solid var(--line);border-radius:12px;padding:6px}
.search-form input{border:0;background:transparent;padding:11px 12px;outline:none}
.search-form button{border:0;border-radius:9px;background:var(--violet);color:#fff;padding:0 16px;font-weight:900}
.category-strip{display:flex;gap:10px;overflow:auto;padding:8px 0 30px}
.category-strip a{border:1px solid var(--line);border-radius:999px;padding:8px 12px;background:#fff;color:var(--violet);font-weight:800}
.page-title{padding:50px 0 20px}
.pagination{padding-bottom:60px}
@media(max-width:980px){
  .header-inner{min-height:76px}
  .main-nav{display:none;position:absolute;left:20px;right:20px;top:82px;margin:0;background:#fff;border:1px solid var(--line);border-radius:16px;padding:18px;box-shadow:var(--shadow)}
  .main-nav.is-open{display:block}
  .main-nav ul{display:grid;gap:14px}
  .main-nav a:after{display:none}
  .menu-toggle{display:block;margin-left:auto}
  .header-cta{display:none}
  .hero-grid,.single-hero-grid,.article-shell,.contact-grid,.about-grid{grid-template-columns:1fr}
  .hero-art{min-height:330px}
  .speech{right:5%;top:28px}
  .service-grid{grid-template-columns:repeat(2,1fr)}
  .project-grid,.post-grid,.contact-cards,.footer-grid,.about-values,.project-facts{grid-template-columns:1fr}
  .article-sidebar{position:static}
  .cta-band{margin-bottom:0;flex-wrap:wrap}
  .site-footer{padding-top:52px}
  .footer-bottom{display:block}
  .footer-bottom a{margin:0 16px 0 0}
}
@media(max-width:640px){
  .container{width:min(100% - 28px,1180px)}
  .logo-text{font-size:1.55rem}
  .logo-text small{font-size:.54rem}
  .logo-mark{width:38px;height:38px}
  .hero{padding:44px 0}
  .hero h1,.single-hero h1{font-size:2.45rem}
  .hero-text{font-size:1rem}
  .hero-points{gap:12px}
  .hero-points span{width:100%}
  .mascot-xl{width:210px;height:210px}
  .speech{position:relative;right:auto;top:auto;margin-top:-10px;font-size:1rem}
  .hero-art{min-height:auto;gap:16px}
  .service-grid{grid-template-columns:1fr}
  .section-head{display:block}
  .contact-form{grid-template-columns:1fr}
  .contact-cards article{grid-template-columns:1fr}
  .cta-band{padding:28px 24px}
  .cta-band h2{font-size:1.6rem}
  .article-content h2{padding-left:0}
  .article-content h2:before{display:none}
}
