html,body{margin:0;padding:0;font-family:'Noto Sans',sans-serif;font-size:17px;line-height:1.75;-webkit-font-smoothing:subpixel-antialiased;background-color:#fff;color:#1a1a1a;overflow-x:hidden}
::selection{background:linear-gradient(90deg,#316EF2,#A72C1E);color:#fff}
.page-outer{max-width:1366px;margin:0 auto;width:100%}
.site-header{background:#ffffffb8;backdrop-filter:blur(18px);-webkit-backdrop-filter:blur(18px);box-shadow:0 2px 24px #316ef21a;border-bottom:1.5px solid #316ef221;position:relative;z-index:100}
.header-inner{max-width:1366px;margin:0 auto;padding:0 32px}
.header-top{display:flex;justify-content:center;align-items:center;padding:20px 0 12px}
.logo-zone{display:flex;align-items:center;gap:14px;padding-right:20px;border-right:3px solid #316EF2}
.logo-container{width:56px;height:56px;display:flex;align-items:center;justify-content:center;background:#fff;border-radius:14px;box-shadow:0 0 0 2px #316EF2,0 4px 14px #316ef22e;padding:4px;flex-shrink:0}
.logo-container img{width:50px;height:50px;object-fit:contain;display:block}
.brand-name{font-size:1.65rem;font-weight:700;letter-spacing:-.02em;color:#1a1a1a;-webkit-font-smoothing:antialiased;white-space:nowrap}
.header-accent{width:8px;height:8px;background:#FCDB96;border-radius:50%;margin-left:18px;box-shadow:0 0 0 3px #fcdb9659;flex-shrink:0}
.header-navigation{display:flex;justify-content:center;align-items:center;padding:0 0 14px;flex-wrap:wrap;gap:4px 0}
.navigation-list{list-style:none;margin:0;padding:0;display:flex;align-items:center;flex-wrap:wrap;justify-content:center;gap:4px 2px}
.navigation-list li{display:flex;align-items:center}
.navigation-list li a{display:block;padding:8px 18px;font-size:.95rem;font-weight:400;color:#1a1a1a;text-decoration:none;border-radius:20px;letter-spacing:.01em;position:relative;z-index:101;overflow:hidden;transition:color .22s ease-in-out}
.navigation-list li a::before{content:'';position:absolute;top:0;right:0;bottom:0;left:100%;background:linear-gradient(90deg,#316EF2,#2558c9);border-radius:20px;transition:left .28s ease-in-out;z-index:-1}
.navigation-list li a:hover::before{left:0}
.navigation-list li a:hover{color:#fff}
.navigation-list li a.active{background:#316EF2;color:#fff}
.navigation-separator{width:4px;height:4px;background:#316ef24d;border-radius:50%;margin:0 4px;flex-shrink:0}
.site-footer{background:#f5f7fc;border-top:2px solid #316ef224;box-shadow:inset 0 4px 18px #316ef20f;margin-top:auto}
.footer-inner{max-width:1366px;margin:0 auto;padding:0 32px}
.footer-top-row{padding:40px 0 28px;border-bottom:1px solid #316ef21f;display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:20px}
.footer-brand{display:flex;align-items:center;gap:14px}
.footer-logo-container{width:52px;height:52px;display:flex;align-items:center;justify-content:center;background:#fff;border-radius:14px;box-shadow:0 0 0 2px #316EF2,0 4px 12px #316ef226;padding:4px;flex-shrink:0}
.footer-logo-container img{width:44px;height:44px;object-fit:contain;display:block}
.footer-brand-info{display:flex;flex-direction:column;gap:2px}
.footer-brand-name{font-size:1.2rem;font-weight:700;color:#1a1a1a;letter-spacing:-.01em;-webkit-font-smoothing:antialiased}
.footer-credential{font-size:.82rem;color:#5a6270;letter-spacing:.02em}
.footer-contact-block{display:flex;flex-direction:column;gap:7px;align-items:flex-end}
.footer-contact-item{display:flex;align-items:center;gap:9px;font-size:.88rem;color:#3a4050;text-decoration:none;transition:color .2s ease-in-out}
.footer-contact-item:hover{color:#316EF2}
.footer-contact-item span{display:flex;align-items:center}
.footer-columns{display:grid;grid-template-columns:1fr 1fr 1fr;gap:32px;padding:32px 0 28px;border-bottom:1px solid #316ef21a}
.footer-column{display:flex;flex-direction:column;gap:10px}
.footer-column-title{font-size:.82rem;font-weight:700;text-transform:uppercase;letter-spacing:.09em;color:#316EF2;margin-bottom:6px;-webkit-font-smoothing:antialiased}
.footer-column a{font-size:.91rem;color:#3a4050;text-decoration:none;letter-spacing:.01em;transition:color .2s ease-in-out;display:flex;align-items:center;gap:7px}
.footer-column a:hover{color:#316EF2}
.footer-bottom{padding:18px 0 22px;display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:10px}
.footer-copyright{font-size:.82rem;color:#7a8090;letter-spacing:.01em}
.footer-legal-links{display:flex;align-items:center;gap:20px;flex-wrap:wrap}
.footer-legal-links a{font-size:.82rem;color:#7a8090;text-decoration:none;letter-spacing:.01em;transition:color .2s ease-in-out}
.footer-legal-links a:hover{color:#A72C1E}
.cookie-popup-outer{position:fixed;right:28px;top:50%;transform:translateY(-50%) translateY(120px);z-index:9999;width:360px;max-width:calc(100vw - 40px);opacity:0;transition:transform .42s ease-in-out,opacity .38s ease-in-out}
.cookie-popup-outer.open{transform:translateY(-50%);opacity:1}
.cookie-popup-inner{background:#fff;border-radius:22px;box-shadow:0 8px 48px #316ef22e 0 2px 12px #00000017;border:1.5px solid #316ef224;overflow:hidden}
.cookie-tabs{display:flex;border-bottom:1.5px solid #316ef21f}
.cookie-tab{flex:1;padding:12px 10px;font-size:.83rem;font-weight:700;color:#7a8090;background:transparent;border:none;cursor:pointer;letter-spacing:.04em;text-transform:uppercase;transition:color .2s ease-in-out,background .2s ease-in-out}
.cookie-tab.active{color:#316EF2;background:#316ef20f;border-bottom:2px solid #316EF2}
.cookie-panel{display:none;padding:20px 22px 18px}
.cookie-panel.active{display:block}
.cookie-policy-ref{font-size:.8rem;color:#7a8090;margin-bottom:12px;padding-bottom:10px;border-bottom:1px solid #316ef21a}
.cookie-policy-ref a{color:#316EF2;text-decoration:underline}
.cookie-heading{font-size:.97rem;font-weight:700;color:#1a1a1a;margin-bottom:8px;-webkit-font-smoothing:antialiased}
.cookie-text{font-size:.84rem;color:#4a5060;line-height:1.65;margin-bottom:16px}
.cookie-actions{display:flex;gap:18px;justify-content:center}
.cookie-action-link{font-size:.87rem;color:#3a4050;text-decoration:underline;background:transparent;border:none;cursor:pointer;padding:4px 2px;transition:color .2s ease-in-out;font-family:'Noto Sans',sans-serif}
.cookie-action-link:hover{color:#316EF2}
.cookie-category{margin-bottom:14px;padding-bottom:12px;border-bottom:1px solid #316ef214}
.cookie-category:last-of-type{border-bottom:none;margin-bottom:0}
.cookie-category-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:5px}
.cookie-category-label{font-size:.86rem;font-weight:700;color:#1a1a1a}
.cookie-toggle{width:36px;height:20px;background:#d0d4de;border-radius:10px;border:none;cursor:pointer;position:relative;transition:background .22s ease-in-out;flex-shrink:0}
.cookie-toggle::after{content:'';position:absolute;top:3px;left:3px;width:14px;height:14px;background:#fff;border-radius:50%;transition:left .22s ease-in-out}
.cookie-toggle.on{background:#316EF2}
.cookie-toggle.on::after{left:19px}
.cookie-category-desc{font-size:.79rem;color:#7a8090;line-height:1.5}
.cookie-optout-row{display:flex;align-items:center;justify-content:space-between;margin-top:10px;padding:10px 0 6px;border-top:1px solid #a72c1e1f}
.cookie-optout-label{font-size:.82rem;color:#A72C1E;font-weight:700}
.cookie-badge{position:fixed;bottom:24px;right:24px;z-index:9998;width:44px;height:44px;background:#316EF2;border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer;box-shadow:0 4px 16px #316ef259;transition:background .22s ease-in-out}
.cookie-badge:hover{background:#2558c9}
.cookie-badge-icon{width:22px;height:22px;fill:#fff}
@media (max-width: 900px) {
.footer-columns{grid-template-columns:1fr 1fr}
.footer-contact-block{align-items:flex-start}
}
@media (max-width: 600px) {
.header-inner{padding:0 16px}
.footer-inner{padding:0 16px}
.footer-columns{grid-template-columns:1fr}
.footer-top-row{flex-direction:column;align-items:flex-start}
.footer-bottom{flex-direction:column;align-items:flex-start}
.cookie-popup-outer{right:12px;left:12px;width:auto;top:auto;bottom:12px;transform:translateY(120px)}
.cookie-popup-outer.open{transform:translateY(0)}
}
.doc-content{max-width:860px;margin:0 auto;padding:48px 32px 80px;background:#fff;border-radius:24px;box-shadow:0 8px 48px #316ef214 0 2px 12px #316ef20d}
.doc-content ul,.doc-content ol{padding-left:28px;margin-top:12px;margin-bottom:20px;line-height:1.8}
.doc-content ul{list-style-type:disc}
.doc-content ol{list-style-type:decimal}
.doc-content ul ul,.doc-content ol ol,.doc-content ul ol,.doc-content ol ul{margin-top:6px;margin-bottom:6px}
.doc-content li{margin-bottom:8px;font-size:17px;line-height:1.75;letter-spacing:.01em;color:#1a1a2e;-webkit-font-smoothing:subpixel-antialiased}
.doc-content li::marker{color:#316EF2}
.doc-content strong,.doc-content b{font-weight:700;color:#0f1a3a;letter-spacing:.005em}
.doc-content a{color:#316EF2;text-decoration:underline;text-decoration-color:#316ef259;text-underline-offset:3px;text-decoration-thickness:1px;transition:color .2s ease-in-out,text-decoration-color .2s ease-in-out}
.doc-content a:hover{color:#A72C1E;text-decoration-color:#a72c1e80}
.doc-content a:visited{color:#5a4fcf;text-decoration-color:#5a4fcf4d}
.doc-content table{width:100%;border-collapse:separate;border-spacing:0;margin-top:24px;margin-bottom:32px;font-size:16px;border-radius:16px;overflow:hidden;box-shadow:0 4px 24px #316ef217 0 1px 6px #316ef20f}
.doc-content thead{background:linear-gradient(135deg,#316ef214 0%,#fcdb962e 100%)}
.doc-content thead tr{background:transparent}
.doc-content tbody tr{background:#fff;transition:background .18s ease-in-out}
.doc-content tbody tr:nth-child(even){background:#316ef208}
.doc-content tbody tr:hover{background:#316ef20f}
.doc-content th{padding:14px 20px;font-size:13px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:#0f1a3a;text-align:left;border-bottom:2px solid #316ef22e;-webkit-font-smoothing:antialiased}
.doc-content td{padding:13px 20px;font-size:16px;line-height:1.7;color:#1a1a2e;border-bottom:1px solid #316ef214;vertical-align:top;-webkit-font-smoothing:subpixel-antialiased}
.doc-content tbody tr:last-child td{border-bottom:none}
.doc-content hr{border:none;border-top:1px solid #316ef224;margin:40px 0;position:relative}
.doc-content hr::after{content:'';display:block;width:60px;height:3px;background:linear-gradient(90deg,#316EF2,#A72C1E);border-radius:99px;position:absolute;top:-2px;left:0}
.doc-content div{line-height:1.75;color:#1a1a2e;font-size:17px}
@media (max-width: 768px) {
.doc-content{padding:32px 20px 56px;border-radius:16px}
.doc-content table{display:block;overflow-x:auto;-webkit-overflow-scrolling:touch;border-radius:12px}
.doc-content th,.doc-content td{padding:11px 14px;font-size:15px}
.doc-content li{font-size:16px}
.doc-content div{font-size:16px}
}
@media (max-width: 480px) {
.doc-content{padding:24px 16px 40px;border-radius:12px;box-shadow:0 4px 20px #316ef212}
.doc-content ul,.doc-content ol{padding-left:20px}
}
.detail-page{max-width:1366px;margin:0 auto;padding:0;overflow-x:hidden;-webkit-font-smoothing:subpixel-antialiased}
.detail-page ::selection{background:linear-gradient(90deg,#316EF2,#A72C1E);color:#fff}
.detail-page .hero-outer{position:relative;overflow:hidden;background:radial-gradient(ellipse at center,#e8effd 0%,#fff8ee 60%,#fff 100%);padding:80px 48px 64px}
.detail-page .hero-outer::before{content:"";position:absolute;width:480px;height:480px;border-radius:50%;background:#316ef21f;filter:blur(80px);top:-100px;left:-100px;pointer-events:none}
.detail-page .hero-outer::after{content:"\201C";position:absolute;right:60px;top:20px;font-size:320px;line-height:1;color:#316ef212;pointer-events:none;-webkit-font-smoothing:antialiased}
.detail-page .hero-inner{max-width:900px;margin:0 auto;position:relative;z-index:2}
.detail-page .category-tag{display:inline-block;background:#FCDB96;color:#6b4a00;padding:4px 16px;border-radius:20px;font-size:13px;letter-spacing:.08em;margin-bottom:24px}
.detail-page .hero-title{font-size:48px;line-height:1.2;letter-spacing:-.02em;text-align:center;margin-bottom:24px;-webkit-font-smoothing:antialiased}
.detail-page .hero-title .accent-word{color:#316EF2}
.detail-page .hero-meta{display:flex;gap:32px;justify-content:center;flex-wrap:wrap;margin-bottom:40px}
.detail-page .meta-item{display:flex;align-items:center;gap:8px;font-size:14px;color:#555}
.detail-page .meta-item i{color:#316EF2}
.detail-page .hero-image-wrap{border-radius:24px;overflow:hidden;box-shadow:0 24px 64px #316ef22e;margin-top:16px;max-height:420px}
.detail-page .hero-image-wrap img{width:100%;height:420px;object-fit:cover;display:block;animation:scale-down 1s ease-in-out forwards}
@keyframes scale-down {
from{transform:scale(1.06)}
to{transform:scale(1)}
}
.detail-page .body-outer{padding:64px 48px;background:#fff}
.detail-page .body-inner{max-width:900px;margin:0 auto;display:grid;grid-template-columns:1fr 320px;gap:48px;align-items:start}
.detail-page .content-col h2{font-size:28px;letter-spacing:-.01em;margin-bottom:16px;-webkit-font-smoothing:antialiased}
.detail-page .content-col h3{font-size:20px;letter-spacing:0;margin-bottom:12px;-webkit-font-smoothing:antialiased}
.detail-page .content-col p{font-size:17px;line-height:1.8;color:#2a2a2a;margin-bottom:20px}
.detail-page .content-col ol{padding-left:20px;margin-bottom:24px}
.detail-page .content-col li{font-size:17px;line-height:1.8;margin-bottom:8px;color:#2a2a2a;list-style:none;padding-left:0}
.detail-page .content-col ul{padding-left:0;margin-bottom:24px}
.detail-page .content-col blockquote{border-left:4px solid #316EF2;padding:16px 24px;background:#f0f5ff;border-radius:0 16px 16px 0;margin:24px 0;font-size:17px;line-height:1.8;color:#1a1a1a}
.detail-page .content-col cite{font-size:14px;color:#888;font-style:normal}
.detail-page .content-col details{border:1px dashed #316EF2;border-radius:16px;padding:16px 20px;margin-bottom:16px}
.detail-page .content-col summary{cursor:pointer;font-size:16px;color:#316EF2;font-weight:600;letter-spacing:.01em}
.detail-page .content-col dl{margin-bottom:24px}
.detail-page .content-col dt{font-weight:700;color:#1a1a1a;font-size:16px;margin-bottom:4px}
.detail-page .content-col dd{margin:0 0 16px;color:#444;font-size:16px;line-height:1.7}
.detail-page .divider{border:none;border-top:2px dashed #316EF2;margin:40px 0;opacity:.4}
.detail-page .sidebar-col{position:sticky;top:32px}
.detail-page .price-card{border-radius:24px;box-shadow:0 8px 40px #316ef224 inset 0 0 0 1px #316ef21a;padding:32px 28px;background:#fff;margin-bottom:24px}
.detail-page .price-label{font-size:13px;letter-spacing:.1em;color:#888;text-transform:uppercase;margin-bottom:8px}
.detail-page .price-value{font-size:40px;font-weight:800;color:#316EF2;letter-spacing:-.02em;line-height:1;margin-bottom:8px;-webkit-font-smoothing:antialiased}
.detail-page .price-desc{font-size:14px;color:#666;line-height:1.6;margin-bottom:24px}
.detail-page .enroll-button{display:block;width:100%;text-align:center;background:#316EF2;color:#fff;border-radius:16px;padding:16px 0;font-size:16px;font-weight:700;text-decoration:none;position:relative;overflow:hidden;z-index:2;transition:color .3s ease-in-out}
.detail-page .enroll-button::before{content:"";position:absolute;top:0;right:0;width:0;height:100%;background:#A72C1E;z-index:-1;transition:width .3s ease-in-out;border-radius:16px}
.detail-page .enroll-button:hover::before{width:100%;right:auto;left:0}
.detail-page .info-card{border-radius:24px;box-shadow:0 8px 40px #316ef21a;padding:24px;background:#fff}
.detail-page .info-row{display:flex;justify-content:space-between;align-items:center;padding:12px 0;border-bottom:1px dashed #e0e0e0;font-size:14px}
.detail-page .info-row:last-child{border-bottom:none}
.detail-page .info-row-label{color:#888}
.detail-page .info-row-value{color:#1a1a1a;font-weight:600}
.detail-page .likes-row{display:flex;align-items:center;gap:6px;margin-top:16px}
.detail-page .likes-row i{color:#A72C1E}
.detail-page .likes-count{font-size:14px;color:#555}
.detail-page .program-section{padding:48px;background:linear-gradient(135deg,#f0f5ff 0%,#fff8ee 100%)}
.detail-page .program-inner{max-width:900px;margin:0 auto}
.detail-page .program-heading{font-size:32px;text-align:center;letter-spacing:-.01em;margin-bottom:40px;-webkit-font-smoothing:antialiased}
.detail-page .program-heading span{letter-spacing:.08em;color:#316EF2}
.detail-page .program-content h2{font-size:22px;margin-bottom:12px;-webkit-font-smoothing:antialiased}
.detail-page .program-content h3{font-size:18px;margin-bottom:10px}
.detail-page .program-content p{font-size:16px;line-height:1.8;color:#333;margin-bottom:16px}
.detail-page .program-content ol{counter-reset:prog;padding-left:0;margin-bottom:24px}
.detail-page .program-content li{counter-increment:prog;list-style:none;display:flex;gap:16px;align-items:flex-start;margin-bottom:16px;font-size:16px;line-height:1.7;color:#2a2a2a}
.detail-page .program-content li::before{content:counter(prog);min-width:32px;height:32px;border-radius:50%;background:#316EF2;color:#fff;display:flex;align-items:center;justify-content:center;font-size:14px;font-weight:700;flex-shrink:0}
.detail-page .program-content details{border:1px dashed #A72C1E;border-radius:16px;padding:16px 20px;margin-bottom:16px}
.detail-page .program-content summary{cursor:pointer;font-size:16px;color:#A72C1E;font-weight:600}
.detail-page .program-content dl dt{font-weight:700;font-size:16px;color:#1a1a1a;margin-bottom:4px}
.detail-page .program-content dl dd{margin:0 0 14px;color:#444;font-size:15px;line-height:1.7}
.detail-page .scroll-top{display:block;margin:48px auto 0;background:#316EF2;color:#fff;border:none;border-radius:50%;width:52px;height:52px;font-size:22px;cursor:pointer;box-shadow:0 8px 24px #316ef24d;text-align:center;line-height:52px;text-decoration:none;position:relative;overflow:hidden;z-index:10;transition:box-shadow .3s ease-in-out}
.detail-page .scroll-top:hover{box-shadow:0 12px 32px #a72c1e59;background:#A72C1E}
.detail-page .scroll-top i{display:inline-block;vertical-align:middle;margin-top:-4px}
.detail-page .scroll-end{text-align:center;padding:32px 48px 64px}
@media (max-width: 900px) {
.detail-page .body-inner{grid-template-columns:1fr}
.detail-page .sidebar-col{position:static}
.detail-page .hero-outer{padding:48px 24px 40px}
.detail-page .body-outer{padding:40px 24px}
.detail-page .program-section{padding:40px 24px}
.detail-page .hero-title{font-size:32px}
}
@keyframes tracking-in {
from{letter-spacing:-.05em;opacity:0}
to{letter-spacing:-.02em;opacity:1}
}
.detail-page .hero-title{animation:tracking-in .8s ease-in-out forwards}
.page-services{max-width:1366px;margin:0 auto;overflow-x:hidden;-webkit-font-smoothing:subpixel-antialiased}
.page-services ::selection{background:linear-gradient(90deg,#316EF2,#A72C1E);color:#fff}
.page-services .hero-outer{position:relative;min-height:88vh;display:grid;grid-template-columns:1fr 1fr;align-items:center;overflow:hidden;background:#fff;padding:80px 60px 60px;gap:60px}
.page-services .hero-outer::before{content:'';position:absolute;top:-80px;left:-80px;width:520px;height:520px;border-radius:50%;background:linear-gradient(135deg,#316ef212,#fcdb961f);z-index:0;pointer-events:none}
.page-services .hero-text-zone{position:relative;z-index:2}
.page-services .hero-label{display:inline-block;letter-spacing:.22em;font-size:11px;text-transform:uppercase;color:#A72C1E;margin-bottom:28px;font-weight:600}
.page-services .hero-text-zone h1{font-size:clamp(2.2rem,4vw,3.6rem);line-height:1.15;letter-spacing:-.02em;color:#111;margin-bottom:28px;-webkit-font-smoothing:antialiased}
.page-services .hero-text-zone h1 span{font-size:1.6em;display:block;color:#316EF2;letter-spacing:-.03em}
.page-services .hero-desc{font-size:17px;line-height:1.8;color:#444;max-width:480px;margin-bottom:40px}
.page-services .hero-cta{display:inline-block;background:#316EF2;color:#fff;padding:16px 40px;border-radius:28px;font-size:15px;font-weight:600;text-decoration:none;position:relative;z-index:10;overflow:hidden;transition:color .3s ease-in-out;box-shadow:0 8px 32px #316ef22e}
.page-services .hero-cta::after{content:'';position:absolute;top:0;right:-100%;bottom:0;width:100%;background:#A72C1E;transition:right .35s ease-in-out;z-index:-1}
.page-services .hero-cta:hover::after{right:0}
.page-services .hero-image-zone{position:relative;z-index:2;height:560px}
.page-services .hero-image-zone img{width:100%;height:100%;object-fit:cover;border-radius:24px;display:block}
.page-services .hero-image-zone::after{content:'';position:absolute;inset:0;border-radius:24px;background:linear-gradient(160deg,#316ef22e 0%,#fcdb9638 100%);mix-blend-mode:multiply;pointer-events:none}
.page-services .hero-deco{position:absolute;bottom:40px;left:50%;transform:translateX(-50%);width:200px;height:2px;z-index:1}
.page-services .hero-deco::before{content:'';position:absolute;left:0;top:0;width:140px;height:2px;background:#316EF2}
.page-services .hero-deco::after{content:'';position:absolute;right:0;top:0;width:40px;height:2px;background:#FCDB96}
.page-services .services-outer{padding:100px 60px;background:#f8f9fc;position:relative}
.page-services .services-outer::before{content:'';position:absolute;top:0;left:0;right:0;height:4px;background:linear-gradient(90deg,#316EF2,#FCDB96,#A72C1E)}
.page-services .section-heading{text-align:center;margin-bottom:64px}
.page-services .section-heading h2{font-size:clamp(1.6rem,3vw,2.4rem);line-height:1.25;color:#111;letter-spacing:-.015em;-webkit-font-smoothing:antialiased;margin-bottom:16px}
.page-services .section-heading p{font-size:16px;color:#666;line-height:1.75;max-width:560px;margin:0 auto}
.page-services .card-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:28px}
.page-services .service-card{background:#fff;border-radius:24px;overflow:hidden;box-shadow:0 4px 28px #316ef214;transition:box-shadow .3s ease-in-out,transform .3s ease-in-out;display:flex;flex-direction:column}
.page-services .service-card:hover{box-shadow:0 12px 48px #316ef229;transform:translateY(-4px)}
.page-services .card-image{width:100%;height:220px;overflow:hidden;position:relative}
.page-services .card-image img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .5s ease-in-out}
.page-services .service-card:hover .card-image img{transform:scale(1.04)}
.page-services .card-body{padding:32px 28px 36px;flex:1;display:flex;flex-direction:column}
.page-services .card-icon{width:44px;height:44px;border-radius:14px;background:linear-gradient(135deg,#316ef21a,#fcdb9633);display:flex;align-items:center;justify-content:center;margin-bottom:20px;box-shadow:inset 0 2px 8px #316ef21f}
.page-services .card-icon i{font-size:20px;color:#316EF2}
.page-services .card-body h4{font-size:1.12rem;color:#111;margin-bottom:12px;letter-spacing:-.01em;line-height:1.35;-webkit-font-smoothing:antialiased}
.page-services .card-body p{font-size:15px;color:#555;line-height:1.78;flex:1;margin-bottom:24px}
.page-services .card-link{display:inline-flex;align-items:center;gap:8px;font-size:14px;font-weight:600;color:#316EF2;text-decoration:none;letter-spacing:.02em;transition:gap .25s ease-in-out;position:relative;z-index:5}
.page-services .card-link:hover{gap:14px;color:#A72C1E}
.page-services .card-link i{font-size:16px}
.page-services .info-outer{padding:100px 60px;background:#fff;display:grid;grid-template-columns:260px 1fr 260px;gap:60px;align-start:start}
.page-services .toc-sidebar{position:sticky;top:24px;align-self:start}
.page-services .toc-sidebar h5{font-size:11px;letter-spacing:.2em;text-transform:uppercase;color:#999;margin-bottom:20px;font-weight:600}
.page-services .toc-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:4px}
.page-services .toc-list li a{display:block;padding:10px 14px;border-radius:10px;font-size:14px;color:#555;text-decoration:none;line-height:1.5;transition:background .2s ease-in-out,color .2s ease-in-out;border-left:2px solid transparent}
.page-services .toc-list li a:hover,.page-services .toc-list li a:focus{background:#316ef212;color:#316EF2;border-left-color:#316EF2}
.page-services .info-center{min-width:0}
.page-services .info-section{margin-bottom:64px;scroll-margin-top:40px}
.page-services .info-section:last-child{margin-bottom:0}
.page-services .info-section h3{font-size:1.35rem;color:#111;margin-bottom:18px;letter-spacing:-.015em;-webkit-font-smoothing:antialiased;padding-bottom:12px;border-bottom:1px solid #eee}
.page-services .info-section p{font-size:16px;color:#444;line-height:1.8;margin-bottom:16px}
.page-services .info-section p:last-child{margin-bottom:0}
.page-services .pyramid-outer{display:flex;flex-direction:column;align-items:center;gap:8px;padding:32px 0}
.page-services .pyramid-layer{border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:600;color:#fff;text-align:center;padding:14px 20px;letter-spacing:.02em;box-shadow:0 3px 12px #316ef22e}
.page-services .pyramid-layer-1{width:90%;background:#316EF2}
.page-services .pyramid-layer-2{width:72%;background:linear-gradient(90deg,#316EF2,#A72C1E)}
.page-services .pyramid-layer-3{width:52%;background:#A72C1E}
.page-services .pyramid-layer-4{width:34%;background:#7a1a10;font-size:12px}
.page-services .right-sidebar{position:sticky;top:24px;align-self:start}
.page-services .contact-card{background:linear-gradient(160deg,#316EF2 0%,#1a3fa0 100%);border-radius:22px;padding:32px 24px;color:#fff;box-shadow:0 8px 32px #316ef238}
.page-services .contact-card h5{font-size:1.05rem;margin-bottom:14px;letter-spacing:-.01em}
.page-services .contact-card p{font-size:13px;line-height:1.7;color:#ffffffd1;margin-bottom:22px}
.page-services .contact-card a{display:block;background:#fff;color:#316EF2;text-align:center;padding:12px 20px;border-radius:14px;font-size:14px;font-weight:700;text-decoration:none;transition:background .25s ease-in-out;position:relative;z-index:5}
.page-services .contact-card a:hover{background:#FCDB96;color:#111}
.page-services .contact-card .contact-detail{font-size:12px;color:#ffffffb3;margin-top:16px;display:flex;flex-direction:column;gap:6px}
.page-services .contact-card .contact-detail span{display:flex;align-items:center;gap:8px}
@media (max-width: 1100px) {
.page-services .card-grid{grid-template-columns:repeat(2,1fr)}
.page-services .info-outer{grid-template-columns:200px 1fr;grid-template-rows:auto auto}
.page-services .right-sidebar{grid-column:1 / -1;position:static}
}
@media (max-width: 768px) {
.page-services .hero-outer{grid-template-columns:1fr;padding:60px 24px 40px;min-height:auto;gap:36px}
.page-services .hero-image-zone{height:320px}
.page-services .services-outer,.page-services .info-outer{padding:60px 24px}
.page-services .card-grid{grid-template-columns:1fr}
.page-services .info-outer{grid-template-columns:1fr}
.page-services .toc-sidebar,.page-services .right-sidebar{position:static}
}
.page-services .sidebar-photo{object-fit:cover;display:block}
.about-page{max-width:1366px;margin:0 auto;overflow-x:hidden;background:#fff}
.about-page ::selection{background:linear-gradient(90deg,#316EF2,#A72C1E);color:#fff}
.about-page .hero-outer{position:relative;min-height:520px;display:grid;grid-template-columns:1fr 2fr;align-items:center;gap:0;overflow:hidden;background:#f7f8fc;border-radius:0 0 32px 32px;box-shadow:0 8px 48px #316ef214}
.about-page .hero-texture{position:absolute;inset:0;background-image:url("data:image/svg+xml,%3Csvg width='200' height='200' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.75' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='200' height='200' filter='url(%23n)' opacity='0.04'/%3E%3C/svg%3E");background-size:200px;pointer-events:none;z-index:0}
.about-page .hero-text-zone{position:relative;z-index:2;padding:64px 48px 64px 56px}
.about-page .hero-text-zone h1{font-size:2.6rem;line-height:1.18;letter-spacing:-.02em;color:#111;margin-bottom:20px;-webkit-font-smoothing:auto;font-smoothing:auto;text-align:center}
.about-page .hero-text-zone h1 span{font-size:3.6rem;display:block;color:#316EF2;letter-spacing:-.03em}
.about-page .hero-desc{font-size:1.06rem;line-height:1.78;color:#333;max-width:480px;letter-spacing:.01em}
.about-page .hero-bracket{position:absolute;top:28px;left:28px;width:38px;height:38px;border-top:3px solid #316EF2;border-left:3px solid #316EF2;border-radius:4px 0 0 0}
.about-page .hero-bracket-bottom{position:absolute;bottom:28px;right:28px;width:38px;height:38px;border-bottom:3px solid #A72C1E;border-right:3px solid #A72C1E;border-radius:0 0 4px 0}
.about-page .hero-image-zone{position:relative;height:520px;overflow:hidden}
.about-page .hero-image-zone img{width:100%;height:100%;object-fit:cover;object-position:center top;display:block;filter:sepia(0.18) saturate(1.12) contrast(1.04)}
.about-page .hero-image-overlay{position:absolute;inset:0;background:linear-gradient(120deg,#f7f8fc8c 0%,#316ef214 100%)}
.about-page .team-outer{padding:80px 56px 96px}
.about-page .team-inner{display:grid;grid-template-columns:1fr 2fr;gap:56px;align-items:start}
.about-page .team-intro h2{font-size:1.7rem;line-height:1.25;letter-spacing:-.01em;color:#111;text-align:center;margin-bottom:24px;-webkit-font-smoothing:antialiased}
.about-page .team-intro h2 span{font-size:2.4rem;display:block;color:#111}
.about-page .profile-card{background:#fff;border-radius:24px;box-shadow:0 4px 32px #316ef21a inset 0 0 0 1.5px #316ef214;overflow:hidden;max-width:300px}
.about-page .profile-card img{width:100%;height:280px;object-fit:cover;object-position:center top;display:block}
.about-page .profile-info{padding:20px 24px 24px}
.about-page .profile-info h4{font-size:1.05rem;color:#111;margin-bottom:4px;letter-spacing:.02em}
.about-page .profile-role{font-size:.88rem;color:#316EF2;letter-spacing:.09em;text-transform:uppercase;margin-bottom:0}
.about-page .team-content-col{display:flex;flex-direction:column;gap:28px}
.about-page .team-content-col h3{font-size:1.18rem;color:#111;letter-spacing:-.005em;margin-bottom:10px;text-align:center;-webkit-font-smoothing:antialiased}
.about-page .team-content-col p{font-size:1rem;line-height:1.78;color:#2a2a2a;letter-spacing:.008em}
.about-page .guarantee-badge{display:flex;align-items:center;gap:16px;background:linear-gradient(110deg,#316EF2 0%,#A72C1E 100%);border-radius:20px;padding:20px 28px;box-shadow:0 6px 28px #316ef22e;margin-top:8px}
.about-page .badge-icon{flex-shrink:0;width:44px;height:44px;background:#ffffff2e;border-radius:50%;display:flex;align-items:center;justify-content:center;box-shadow:inset 0 0 0 2px #ffffff4d}
.about-page .badge-icon i{color:#FCDB96;font-size:1.2rem}
.about-page .badge-text{color:#fff;font-size:.96rem;line-height:1.5;letter-spacing:.01em}
.about-page .badge-text strong{display:block;font-size:1.06rem;letter-spacing:.03em;margin-bottom:2px;color:#FCDB96}
.about-page .images-strip{display:grid;grid-template-columns:1fr 1fr 1fr;gap:16px;margin-top:12px;border-radius:20px;overflow:hidden}
.about-page .strip-item{position:relative;height:180px;overflow:hidden;border-radius:16px;box-shadow:0 4px 18px #316ef217}
.about-page .strip-item img{width:100%;height:100%;object-fit:cover;object-position:center;display:block;transition:transform .5s ease-in-out}
.about-page .strip-item:hover img{transform:scale(1.06)}
.about-page .strip-overlay{position:absolute;inset:0;background:linear-gradient(180deg,transparent 50%,#316ef238 100%);border-radius:16px}
.about-page .divider-wrap{display:flex;align-items:center;gap:0;padding:0 56px;margin:0 0 12px}
.about-page .divider-line{flex:1;height:1px;background:linear-gradient(90deg,transparent,#316EF2 40%,#A72C1E 60%,transparent)}
.about-page .divider-svg{display:flex;align-items:center;padding:0 8px}
@media (max-width: 900px) {
.about-page .hero-outer{grid-template-columns:1fr;min-height:auto}
.about-page .hero-image-zone{height:280px;order:-1}
.about-page .hero-text-zone{padding:40px 24px}
.about-page .team-inner{grid-template-columns:1fr}
.about-page .profile-card{max-width:100%}
.about-page .team-outer{padding:48px 24px 64px}
.about-page .images-strip{grid-template-columns:1fr}
.about-page .strip-item{height:160px}
.about-page .divider-wrap{padding:0 24px}
}
.contact-page{max-width:1366px;margin:0 auto;overflow-x:hidden;-webkit-font-smoothing:subpixel-antialiased}
.contact-page ::selection{background:linear-gradient(90deg,#316EF2,#A72C1E);color:#fff}
.contact-hero{position:relative;min-height:420px;display:flex;align-items:center;justify-content:center;overflow:hidden;background:#f7f8fc}
.contact-hero-bg{position:absolute;inset:0;background-image:url(./photo_archive/14-hero.jpg);background-size:cover;background-position:center 40%;background-attachment:fixed;filter:brightness(0.38);z-index:0;animation:bg-pan 18s ease-in-out infinite alternate}
@keyframes bg-pan {
from{background-position:0 40%}
to{background-position:100% 40%}
}
.contact-hero-inner{position:relative;z-index:2;text-align:center;padding:64px 24px 56px;max-width:680px}
.contact-hero-inner h1{color:#fff;font-size:clamp(2rem,4vw,3.2rem);line-height:1.2;letter-spacing:-.02em;margin-bottom:16px;-webkit-font-smoothing:antialiased}
.contact-hero-inner h1 span{color:#FCDB96;letter-spacing:.06em;font-size:1.1em}
.contact-hero-inner p{color:#ffffffd1;font-size:1.05rem;line-height:1.75;margin:0}
.contact-main-block{background:#fff;padding:80px 24px 96px}
.contact-main-inner{max-width:1060px;margin:0 auto;display:grid;grid-template-columns:1fr 1.5fr;gap:64px;align-items:start}
.contact-info-col h2{font-size:clamp(1.4rem,2.5vw,2rem);line-height:1.25;letter-spacing:-.01em;margin-bottom:20px;-webkit-font-smoothing:antialiased;color:#111}
.contact-info-col h2 span{font-size:1.3em;color:#316EF2;letter-spacing:-.03em}
.contact-info-col p{font-size:.97rem;line-height:1.78;color:#444;margin-bottom:32px}
.contact-details-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:18px}
.contact-details-list li{display:flex;align-items:flex-start;gap:14px;font-size:.95rem;color:#333;line-height:1.6}
.detail-icon{display:inline-flex;align-items:center;justify-content:center;width:38px;height:38px;border-radius:50%;background:#f0f4ff;box-shadow:inset 0 2px 6px #316ef221;flex-shrink:0;margin-top:1px}
.detail-icon i{color:#316EF2;font-size:14px}
.detail-label{font-size:.78rem;letter-spacing:.09em;color:#316EF2;text-transform:uppercase;display:block;margin-bottom:2px}
.detail-value{color:#222;font-size:.96rem}
.detail-value a{color:#222;text-decoration:none;border-bottom:1px solid #316ef24d;transition:border-color .2s ease-in-out,color .2s ease-in-out}
.detail-value a:hover{color:#316EF2;border-color:#316EF2}
.contact-form-col{background:#f9fafe;border-radius:24px;padding:44px 40px 48px;box-shadow:0 8px 40px #316ef217 inset 0 2px 8px #316ef20f}
.contact-form-col h3{font-size:1.25rem;color:#111;margin-bottom:28px;letter-spacing:-.01em;-webkit-font-smoothing:antialiased}
.contact-form-col form{display:flex;flex-direction:column;gap:18px}
.field-row{display:flex;flex-direction:column;gap:6px}
.field-row label{font-size:.83rem;letter-spacing:.06em;color:#555;text-transform:uppercase}
.contact-form-col input[type="text"],.contact-form-col input[type="email"],.contact-form-col input[type="tel"],.contact-form-col select{width:100%;padding:13px 16px;border-radius:12px;border:none;background:#fff;box-shadow:0 2px 10px #316ef214 inset 0 1px 4px #316ef212;font-size:.97rem;color:#222;outline:none;transition:box-shadow .2s ease-in-out;-webkit-appearance:none;appearance:none}
.contact-form-col input[type="text"]:focus,.contact-form-col input[type="email"]:focus,.contact-form-col input[type="tel"]:focus,.contact-form-col select:focus{box-shadow:0 0 0 3px #316ef238 inset 0 1px 4px #316ef21a}
.contact-form-col select{cursor:pointer;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%23316EF2' stroke-width='1.8' fill='none' stroke-linecap='round'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 14px center;padding-right:38px}
.radio-group-label{font-size:.83rem;letter-spacing:.06em;color:#555;text-transform:uppercase;margin-bottom:6px;display:block}
.radio-group{display:flex;flex-wrap:wrap;gap:10px}
.radio-option{position:relative}
.radio-option input[type="radio"]{position:absolute;opacity:0;width:0;height:0}
.radio-option label{display:inline-block;padding:9px 18px;border-radius:20px;background:#fff;box-shadow:0 2px 8px #316ef214;font-size:.88rem;color:#444;cursor:pointer;transition:background .2s ease-in-out,color .2s ease-in-out,box-shadow .2s ease-in-out;letter-spacing:0;text-transform:none}
.radio-option input[type="radio"]:checked + label{background:#316EF2;color:#fff;box-shadow:0 4px 14px #316ef247}
.radio-option input[type="radio"]:focus + label{outline:2px solid #316EF2;outline-offset:2px}
.privacy-row{display:flex;align-items:flex-start;gap:12px;margin-top:4px}
.privacy-row input[type="checkbox"]{width:18px;height:18px;flex-shrink:0;margin-top:2px;accent-color:#316EF2;cursor:pointer}
.privacy-row span{font-size:.84rem;color:#666;line-height:1.6}
.privacy-row a{color:#316EF2;text-decoration:underline}
.submit-button{position:relative;overflow:hidden;background:#316EF2;color:#fff;border:none;border-radius:16px;padding:15px 36px;font-size:1rem;cursor:pointer;letter-spacing:.04em;transition:color .25s ease-in-out;z-index:2;text-align:center;margin-top:6px}
.submit-button::before{content:'';position:absolute;inset:0;background:#A72C1E;transform:translateX(100%);transition:transform .3s ease-in-out;z-index:-1;border-radius:16px}
.submit-button:hover::before{transform:translateX(0)}
.submit-button:focus{outline:3px solid #FCDB96;outline-offset:3px}
@media (max-width: 860px) {
.contact-main-inner{grid-template-columns:1fr;gap:40px}
.contact-form-col{padding:32px 24px 36px}
}
@media (max-width: 520px) {
.contact-hero-inner h1{font-size:1.7rem}
.radio-group{flex-direction:column}
}
.page-services{max-width:1366px;margin:0 auto;overflow-x:hidden;background:#fff}
.page-services ::selection{background:linear-gradient(90deg,#316EF2,#A72C1E);color:#fff}
.page-services .title-block{position:relative;text-align:center;padding:90px 40px 80px;overflow:hidden;background:#f8f9ff}
.page-services .title-block .bg-pattern{position:absolute;inset:0;z-index:0;background-image:url("data:image/svg+xml,%3Csvg width='800' height='400' viewBox='0 0 800 400' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M0 200 Q200 50 400 200 Q600 350 800 200' stroke='%23316EF2' stroke-opacity='0.07' stroke-width='2' fill='none'/%3E%3Cpath d='M0 250 Q200 100 400 250 Q600 400 800 250' stroke='%23A72C1E' stroke-opacity='0.05' stroke-width='2' fill='none'/%3E%3Cpath d='M0 150 Q200 0 400 150 Q600 300 800 150' stroke='%23316EF2' stroke-opacity='0.05' stroke-width='1.5' fill='none'/%3E%3C/svg%3E");background-size:800px 400px;animation:pattern-shift 12s ease-in-out infinite alternate}
@keyframes pattern-shift {
0%{background-position:0 0}
100%{background-position:80px 20px}
}
.page-services .title-block .eyebrow{position:relative;z-index:1;display:inline-block;font-size:12px;letter-spacing:.2em;text-transform:uppercase;color:#A72C1E;margin-bottom:16px}
.page-services .title-block h1{position:relative;z-index:1;font-size:48px;line-height:1.2;letter-spacing:-.02em;color:#111;margin:0;-webkit-font-smoothing:auto}
.page-services .title-block h1 span{font-size:72px;display:block;color:#316EF2;letter-spacing:-.03em}
.page-services .blur-divider{height:2px;background:linear-gradient(90deg,transparent,#316EF2 30%,#A72C1E 70%,transparent);filter:blur(1px);margin:0;opacity:.4}
.page-services .services-grid-outer{padding:80px 60px;background:#fff}
.page-services .services-grid-inner{max-width:900px;margin:0 auto}
.page-services .services-grid-inner h2{text-align:center;font-size:32px;letter-spacing:-.01em;color:#111;margin-bottom:48px;-webkit-font-smoothing:antialiased}
.page-services .service-columns{columns:2;column-gap:32px}
.page-services .service-card{break-inside:avoid;margin-bottom:28px;padding:28px 32px;border-radius:20px;box-shadow:0 4px 24px #316ef21a inset 0 1px 0 #316ef214;background:#fff;transition:box-shadow .3s ease-in-out,transform .3s ease-in-out}
.page-services .service-card:hover{box-shadow:0 8px 40px #316ef22e inset 0 2px 0 #a72c1e1a;transform:translateY(-3px)}
.page-services .service-card h4{font-size:17px;color:#316EF2;margin-bottom:10px;letter-spacing:.01em;-webkit-font-smoothing:antialiased}
.page-services .service-card p{font-size:15px;line-height:1.75;color:#333;margin:0}
.page-services .service-card .card-icon{margin-bottom:12px;font-size:22px;color:#FCDB96;display:block}
.page-services .process-outer{padding:80px 60px;background:#f8f9ff;overflow:hidden}
.page-services .process-inner{max-width:900px;margin:0 auto}
.page-services .process-inner h2{text-align:center;font-size:32px;color:#111;margin-bottom:56px;letter-spacing:-.01em;-webkit-font-smoothing:antialiased}
.page-services .bracket-wrap{position:relative;padding:0 40px}
.page-services .bracket-wrap::before,.page-services .bracket-wrap::after{content:'';position:absolute;top:0;bottom:0;width:4px;border-radius:4px;background:linear-gradient(180deg,#316EF2,#FCDB96)}
.page-services .bracket-wrap::before{left:0}
.page-services .bracket-wrap::after{right:0}
.page-services .schedule-grid{display:grid;grid-template-columns:1fr 1fr;gap:0}
.page-services .schedule-item{padding:24px 20px;border-bottom:1px solid #316ef214;display:flex;gap:16px;align-items:flex-start}
.page-services .schedule-item:nth-child(odd){border-right:1px solid #316ef214}
.page-services .step-number{font-size:28px;font-weight:700;color:#316ef226;line-height:1;min-width:36px;letter-spacing:-.03em}
.page-services .step-text h5{font-size:15px;color:#111;margin-bottom:6px;letter-spacing:.005em}
.page-services .step-text p{font-size:14px;line-height:1.7;color:#555;margin:0}
.page-services .photos-outer{padding:80px 60px;background:#fff}
.page-services .photos-inner{max-width:900px;margin:0 auto}
.page-services .photos-inner h2{text-align:center;font-size:32px;color:#111;margin-bottom:48px;letter-spacing:-.01em;-webkit-font-smoothing:antialiased}
.page-services .photo-masonry{columns:3;column-gap:20px}
.page-services .photo-item{break-inside:avoid;margin-bottom:20px;border-radius:20px;overflow:hidden;box-shadow:0 4px 20px #316ef21a;position:relative}
.page-services .photo-item img{width:100%;height:auto;display:block;object-fit:cover;transition:transform .5s ease-in-out}
.page-services .photo-item:hover img{transform:scale(1.04)}
.page-services .photo-item .photo-overlay{position:absolute;inset:0;background:linear-gradient(180deg,transparent 50%,#316ef28c 100%);opacity:0;transition:opacity .4s ease-in-out;border-radius:20px}
.page-services .photo-item:hover .photo-overlay{opacity:1}
.page-services .team-outer{padding:80px 60px 100px;background:#f8f9ff}
.page-services .team-inner{max-width:900px;margin:0 auto}
.page-services .team-inner h2{text-align:center;font-size:32px;color:#111;margin-bottom:12px;letter-spacing:-.01em;-webkit-font-smoothing:antialiased}
.page-services .team-intro{text-align:center;font-size:16px;color:#555;line-height:1.75;margin-bottom:48px;max-width:600px;margin-left:auto;margin-right:auto}
.page-services .team-row{display:grid;grid-template-columns:1fr 1fr 1fr;gap:24px}
.page-services .team-card{border-radius:24px;overflow:hidden;box-shadow:0 4px 24px #316ef217;background:#fff;transition:box-shadow .3s ease-in-out}
.page-services .team-card:hover{box-shadow:0 10px 40px #316ef229}
.page-services .team-photo{width:100%;height:220px;overflow:hidden;position:relative}
.page-services .team-photo img{width:100%;height:100%;object-fit:cover;object-position:center top;display:block;transition:transform .5s ease-in-out}
.page-services .team-card:hover .team-photo img{transform:scale(1.05)}
.page-services .team-info{padding:20px 22px}
.page-services .team-info h5{font-size:16px;color:#111;margin-bottom:4px}
.page-services .team-info .role-label{font-size:13px;color:#316EF2;letter-spacing:.08em;text-transform:uppercase;margin-bottom:10px;display:block}
.page-services .team-info p{font-size:14px;line-height:1.72;color:#555;margin:0}
@media (max-width: 900px) {
.page-services .service-columns{columns:1}
.page-services .schedule-grid{grid-template-columns:1fr}
.page-services .schedule-item:nth-child(odd){border-right:none}
.page-services .photo-masonry{columns:2}
.page-services .team-row{grid-template-columns:1fr 1fr}
.page-services .title-block h1 span{font-size:52px}
}
@media (max-width: 600px) {
.page-services .services-grid-outer,.page-services .process-outer,.page-services .photos-outer,.page-services .team-outer{padding:60px 24px}
.page-services .photo-masonry{columns:1}
.page-services .team-row{grid-template-columns:1fr}
.page-services .bracket-wrap{padding:0 20px}
.page-services .title-block h1 span{font-size:40px}
}
.page-learning{max-width:1366px;margin:0 auto;padding:0;overflow-x:hidden;-webkit-font-smoothing:subpixel-antialiased}
.page-learning ::selection{background:linear-gradient(90deg,#316EF2,#A72C1E);color:#fff}
.page-learning .hero-outer{position:relative;display:grid;grid-template-columns:1fr 2fr;min-height:480px;overflow:hidden}
.page-learning .hero-solid{background:#f8f8f8;padding:64px 48px 64px 56px;display:flex;flex-direction:column;justify-content:center;position:relative;z-index:2}
.page-learning .hero-solid::before{content:"\201C";position:absolute;top:20px;left:24px;font-size:220px;color:#316EF2;opacity:.07;line-height:1;pointer-events:none}
.page-learning .hero-tag{display:inline-block;letter-spacing:.18em;font-size:11px;text-transform:uppercase;color:#316EF2;margin-bottom:20px}
.page-learning .hero-solid h1{font-size:2.1rem;line-height:1.25;letter-spacing:-.02em;-webkit-font-smoothing:antialiased;margin-bottom:20px;color:#111}
.page-learning .hero-solid h1 span{font-size:2.9rem;display:block}
.page-learning .hero-solid p{font-size:16px;line-height:1.75;color:#444;max-width:380px}
.page-learning .hero-image-side{position:relative;overflow:hidden}
.page-learning .hero-image-side img{width:100%;height:100%;object-fit:cover;object-position:center;display:block;filter:sepia(0.4) hue-rotate(180deg) saturate(1.4);mix-blend-mode:multiply}
.page-learning .hero-image-side::after{content:"";position:absolute;inset:0;background:linear-gradient(135deg,#316ef28c,#a72c1e73)}
.page-learning .divider-outer{display:flex;align-items:center;justify-content:center;padding:36px 0 8px;gap:12px}
.page-learning .divider-line{width:80px;height:1px;background:#316EF2}
.page-learning .divider-diamond{width:8px;height:8px;background:#316EF2;transform:rotate(45deg)}
.page-learning .programs-outer{padding:16px 48px 72px;position:relative}
.page-learning .programs-outer::before{content:"";position:absolute;inset:0;background-image:repeating-linear-gradient(0deg,transparent,transparent 28px,#316ef20a 28px,#316ef20a 29px),repeating-linear-gradient(90deg,transparent,transparent 28px,#316ef20a 28px,#316ef20a 29px);pointer-events:none;z-index:0}
.page-learning .programs-heading{text-align:center;margin-bottom:48px;position:relative;z-index:1}
.page-learning .programs-heading h2{font-size:1.85rem;letter-spacing:-.015em;-webkit-font-smoothing:antialiased;color:#111;margin-bottom:10px}
.page-learning .programs-heading p{color:#555;font-size:15.5px;line-height:1.75;max-width:560px;margin:0 auto}
.page-learning .card-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:28px;position:relative;z-index:1}
.page-learning .program-card{background:#fff;border-radius:24px;box-shadow:0 4px 32px #316ef21a 0 1px 4px #0000000f;overflow:hidden;display:flex;flex-direction:column;transition:box-shadow .3s ease-in-out,transform .3s ease-in-out;position:relative;z-index:2}
.page-learning .program-card:hover{box-shadow:0 12px 48px #316ef22e 0 2px 8px #00000014;transform:translateY(-4px)}
.page-learning .card-image-wrap{position:relative;height:190px;overflow:hidden}
.page-learning .card-image-wrap img{width:100%;height:100%;object-fit:cover;object-position:top center;display:block;transition:transform .5s ease-in-out}
.page-learning .program-card:hover .card-image-wrap img{transform:scale(1.04)}
.page-learning .card-tag{position:absolute;top:14px;left:14px;background:#316EF2;color:#fff;font-size:11px;letter-spacing:.12em;text-transform:uppercase;padding:4px 12px;border-radius:20px;z-index:3}
.page-learning .card-user-badge{position:absolute;bottom:14px;right:14px;background:#fcdb96f2;color:#5a3c00;font-size:11px;padding:4px 10px;border-radius:20px;letter-spacing:.06em}
.page-learning .card-body{padding:24px 24px 16px;flex:1;display:flex;flex-direction:column}
.page-learning .card-body h4{font-size:1.1rem;line-height:1.4;letter-spacing:-.01em;-webkit-font-smoothing:antialiased;color:#111;margin-bottom:10px}
.page-learning .card-body p{font-size:14.5px;line-height:1.7;color:#555;flex:1;margin-bottom:16px}
.page-learning .card-meta{display:flex;align-items:center;gap:16px;font-size:13px;color:#777;margin-bottom:16px}
.page-learning .card-meta .meta-item{display:flex;align-items:center;gap:5px}
.page-learning .card-footer{padding:16px 24px 24px;display:flex;align-items:center;justify-content:space-between;border-top:1px solid #f0f0f0}
.page-learning .price-block .price-main{font-size:1.35rem;font-weight:700;color:#316EF2;letter-spacing:-.02em}
.page-learning .price-block .price-desc{font-size:12px;color:#888;margin-top:2px}
.page-learning .card-cta{display:inline-block;padding:10px 22px;background:#316EF2;color:#fff;border-radius:20px;font-size:14px;text-decoration:none;position:relative;overflow:hidden;z-index:3;transition:color .3s ease-in-out}
.page-learning .card-cta::before{content:"";position:absolute;inset:0;background:#A72C1E;transform:translateX(100%);transition:transform .3s ease-in-out;z-index:-1}
.page-learning .card-cta:hover::before{transform:translateX(0)}
.page-learning .like-row{display:flex;align-items:center;gap:5px;font-size:12.5px;color:#A72C1E}
.page-learning .rating-outer{background:#fff;margin:0 48px;border-radius:28px;box-shadow:0 4px 40px #316ef217;padding:48px 56px;display:grid;grid-template-columns:1fr 2fr;gap:48px;align-items:start;position:relative;z-index:3;margin-bottom:-32px}
.page-learning .rating-score{text-align:center;padding:24px;background:linear-gradient(135deg,#e8effd,#fff8ee);border-radius:20px;box-shadow:inset 0 2px 12px #316ef214}
.page-learning .rating-score .big-number{font-size:4rem;font-weight:700;color:#316EF2;line-height:1;letter-spacing:-.04em;-webkit-font-smoothing:antialiased}
.page-learning .rating-score .stars-row{color:#FCDB96;font-size:22px;letter-spacing:3px;margin:10px 0 6px}
.page-learning .rating-score .review-count{font-size:13px;color:#888}
.page-learning .rating-bars{display:flex;flex-direction:column;gap:10px;padding-top:8px}
.page-learning .bar-row{display:flex;align-items:center;gap:10px;font-size:13px;color:#555}
.page-learning .bar-track{flex:1;height:7px;background:#eee;border-radius:10px;overflow:hidden}
.page-learning .bar-fill{height:100%;background:linear-gradient(90deg,#316EF2,#FCDB96);border-radius:10px}
.page-learning .bar-label{width:20px;text-align:right}
.page-learning .bar-pct{width:36px;color:#316EF2;font-size:12px}
.page-learning .testimonials-outer{background:linear-gradient(135deg,#f0f5ff 0%,#fff8ee 100%);padding:80px 48px 64px;margin-top:0}
.page-learning .testimonials-heading{text-align:center;margin-bottom:44px}
.page-learning .testimonials-heading h2{font-size:1.75rem;color:#111;letter-spacing:-.015em;-webkit-font-smoothing:antialiased;margin-bottom:8px}
.page-learning .testimonials-heading p{font-size:15px;color:#555;line-height:1.75}
.page-learning .testimonials-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.page-learning .testimonial-card{background:#fff;border-radius:22px;padding:28px;box-shadow:0 3px 24px #316ef214;position:relative}
.page-learning .testimonial-card::before{content:"\201C";position:absolute;top:14px;right:22px;font-size:64px;color:#316EF2;opacity:.1;line-height:1;pointer-events:none}
.page-learning .testimonial-text{font-size:14.5px;line-height:1.75;color:#444;margin-bottom:20px}
.page-learning .testimonial-author{display:flex;align-items:center;gap:12px}
.page-learning .testimonial-author img{width:44px;height:44px;border-radius:50%;object-fit:cover;object-position:top center}
.page-learning .author-name{font-size:14px;font-weight:600;color:#111}
.page-learning .author-label{font-size:12px;color:#888;margin-top:1px}
.page-learning .howto-outer{padding:64px 48px;display:grid;grid-template-columns:1fr 2fr;gap:56px;align-items:start}
.page-learning .howto-intro h2{font-size:1.8rem;color:#111;letter-spacing:-.015em;-webkit-font-smoothing:antialiased;line-height:1.3;margin-bottom:16px}
.page-learning .howto-intro h2 span{font-size:2.4rem;display:block}
.page-learning .howto-intro p{font-size:15px;line-height:1.78;color:#555}
.page-learning .howto-steps{display:flex;flex-direction:column;gap:0}
.page-learning .step-item{display:grid;grid-template-columns:48px 1fr;gap:20px;padding:24px 0;border-bottom:1px solid #eee;align-items:start}
.page-learning .step-item:last-child{border-bottom:none}
.page-learning .step-number{width:44px;height:44px;background:#316EF2;color:#fff;border-radius:14px;display:flex;align-items:center;justify-content:center;font-size:15px;font-weight:700;flex-shrink:0;box-shadow:0 4px 14px #316ef247}
.page-learning .step-content h5{font-size:1rem;color:#111;-webkit-font-smoothing:antialiased;margin-bottom:6px;letter-spacing:-.01em}
.page-learning .step-content p{font-size:14.5px;color:#555;line-height:1.7;margin:0}
@media (max-width: 900px) {
.page-learning .hero-outer{grid-template-columns:1fr}
.page-learning .hero-image-side{height:240px}
.page-learning .rating-outer{grid-template-columns:1fr;gap:28px;margin:0 24px}
.page-learning .testimonials-grid{grid-template-columns:1fr}
.page-learning .howto-outer{grid-template-columns:1fr}
.page-learning .programs-outer{padding:16px 24px 60px}
.page-learning .testimonials-outer{padding:72px 24px 48px}
}
@media (max-width: 600px) {
.page-learning .hero-solid{padding:44px 28px}
.page-learning .card-grid{grid-template-columns:1fr}
.page-learning .howto-outer{padding:48px 24px}
}
.page-success{min-height:100vh;background:#fff;overflow-x:hidden;position:relative}
.page-success::before{content:"";position:fixed;inset:0;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.75' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.04'/%3E%3C/svg%3E");background-size:200px 200px;opacity:.5;pointer-events:none;z-index:0;animation:grain-shift 8s steps(2) infinite}
@keyframes grain-shift {
0%{transform:translate(0,0)}
25%{transform:translate(-3px,2px)}
50%{transform:translate(2px,-3px)}
75%{transform:translate(-2px,-2px)}
100%{transform:translate(0,0)}
}
.page-success *{box-sizing:border-box}
.page-success ::selection{background:linear-gradient(90deg,#316EF2,#A72C1E);color:#fff}
.success-outer{position:relative;z-index:1;max-width:1366px;margin:0 auto;padding:80px 24px 120px;display:flex;justify-content:center;align-items:center;min-height:100vh}
.success-inner{max-width:680px;width:100%;text-align:center}
.badge-wrap{display:flex;justify-content:center;margin-bottom:40px}
.badge-circle{width:96px;height:96px;border-radius:50%;background:linear-gradient(135deg,#316EF2 0%,#FCDB96 100%);display:flex;align-items:center;justify-content:center;box-shadow:0 8px 32px #316ef238 inset 0 2px 8px #fcdb964d;position:relative}
.badge-circle::after{content:"";position:absolute;inset:-6px;border-radius:50%;border:2px dashed #316ef240}
.badge-icon{width:44px;height:44px;border:3px solid #fff;border-radius:50%;display:flex;align-items:center;justify-content:center}
.badge-checkmark{width:22px;height:12px;border-left:3px solid #fff;border-bottom:3px solid #fff;transform:rotate(-45deg) translateY(-2px);display:block}
.success-heading{font-size:2.6rem;line-height:1.2;letter-spacing:-.02em;color:#111;margin-bottom:20px;-webkit-font-smoothing:antialiased}
.success-heading span{display:block;font-size:1rem;letter-spacing:.18em;color:#316EF2;text-transform:uppercase;margin-bottom:10px;font-weight:500}
.success-text{font-size:17px;line-height:1.75;color:#3a3a3a;margin-bottom:16px;text-align:left}
.success-divider{width:60px;height:3px;background:linear-gradient(90deg,#316EF2,#FCDB96);border-radius:2px;margin:32px auto}
.success-card{background:#f9f9fb;border-radius:24px;padding:32px 36px;box-shadow:0 4px 24px #316ef214 inset 0 1px 0 #ffffffe6;margin-bottom:40px;text-align:left}
.success-card-heading{font-size:1.15rem;color:#111;font-weight:600;margin-bottom:14px;-webkit-font-smoothing:antialiased}
.success-steps{list-style:none;padding:0;margin:0}
.success-steps li{padding:10px 0;padding-left:28px;font-size:15px;line-height:1.7;color:#444;position:relative;border-bottom:1px solid #316ef212}
.success-steps li:last-child{border-bottom:none}
.success-steps li::before{content:"";position:absolute;left:0;top:17px;width:10px;height:10px;border-radius:50%;background:linear-gradient(135deg,#316EF2,#FCDB96)}
.success-contact-line{font-size:15px;color:#666;margin-bottom:32px;line-height:1.7;text-align:center}
.success-contact-line a{color:#316EF2;text-decoration:none;border-bottom:1px solid #316ef24d;transition:border-color .2s ease-in-out}
.success-contact-line a:hover{border-color:#316EF2}
.button-wrap{display:flex;justify-content:center;gap:16px;flex-wrap:wrap}
.button-primary{position:relative;z-index:10;display:inline-block;padding:14px 36px;border-radius:32px;background:#316EF2;color:#fff;font-size:15px;font-weight:600;letter-spacing:.02em;text-decoration:none;overflow:hidden;box-shadow:0 4px 18px #316ef247;transition:box-shadow .25s ease-in-out;border:none;cursor:pointer}
.button-primary::before{content:"";position:absolute;inset:0;background:#1a55d4;transform:translateX(101%);transition:transform .3s ease-in-out;z-index:-1;border-radius:32px}
.button-primary:hover::before{transform:translateX(0)}
.button-primary:hover{box-shadow:0 6px 24px #316ef261;color:#fff}
.button-secondary{position:relative;z-index:10;display:inline-block;padding:13px 32px;border-radius:32px;background:transparent;color:#316EF2;font-size:15px;font-weight:500;letter-spacing:.02em;text-decoration:none;border:2px solid #316EF2;overflow:hidden;transition:color .3s ease-in-out,box-shadow .25s ease-in-out;cursor:pointer}
.button-secondary::before{content:"";position:absolute;inset:0;background:#316EF2;transform:translateX(101%);transition:transform .3s ease-in-out;z-index:-1}
.button-secondary:hover::before{transform:translateX(0)}
.button-secondary:hover{color:#fff}
.zigzag-bottom{position:relative;margin-top:60px;height:24px;overflow:hidden}
.zigzag-bottom::before{content:"";position:absolute;bottom:0;left:0;right:0;height:24px;background:linear-gradient(135deg,#f9f9fb 25%,transparent 25%) -12px 0,linear-gradient(225deg,#f9f9fb 25%,transparent 25%) -12px 0,linear-gradient(315deg,#f9f9fb 25%,transparent 25%),linear-gradient(45deg,#f9f9fb 25%,transparent 25%);background-size:24px 24px;background-color:#316EF2;opacity:.12}
@media (max-width: 600px) {
.success-outer{padding:48px 16px 80px}
.success-heading{font-size:1.9rem}
.success-card{padding:24px 20px}
.button-wrap{flex-direction:column;align-items:center}
}