:root{
    --bg:#CFD3DB;
    --paper:#FFFFFF;
    --ink:#1D3557;
    --muted:#4A5976;
    --brand:#1D3557;
    --brand-2:#4A5976;
    --brand2:#757F97;
    --accent:#A1A8B8;
    --line:#CFD3DB;
    --soft:#A1A8B8;
    --danger:#8b1e1e;
    --shadow:0 18px 60px rgba(29,53,87,.10);
    --shadow-strong:0 30px 90px rgba(29,53,87,.20);
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;font-family:ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;background:var(--bg);color:var(--ink);line-height:1.65;overflow-x:hidden}
body.no-scroll,body.site-preloading{overflow:hidden}
a{color:inherit;text-decoration:none}
img,video{max-width:100%;display:block}
button,input,textarea,select{font:inherit}
.container{width:min(1180px,calc(100% - 40px));margin:0 auto}
.skip-link{position:absolute;left:-999px;top:10px;background:var(--ink);color:#FFFFFF;padding:10px 14px;border-radius:10px;z-index:1000}
.skip-link:focus{left:10px}

.site-loader{position:fixed;inset:0;z-index:9999;display:grid;place-items:center;background:radial-gradient(circle at 50% 40%,#FFFFFF 0,#CFD3DB 38%,#CFD3DB 100%);transition:opacity .5s ease,visibility .5s ease}
.site-loader.is-hidden{opacity:0;visibility:hidden;pointer-events:none}
.loader-card{width:min(360px,calc(100% - 40px));border:1px solid rgba(31,58,52,.12);border-radius:34px;background:rgba(255,250,242,.72);-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);box-shadow:var(--shadow);padding:30px;text-align:center;display:grid;gap:10px;justify-items:center}
.loader-mark{display:grid;place-items:center;width:70px;height:70px;border-radius:28px;background:linear-gradient(135deg,var(--brand),var(--brand-2));color:#FFFFFF;font-size:38px;animation:loaderPulse 1.6s ease-in-out infinite}
.loader-card strong{font-size:24px;letter-spacing:-.04em}.loader-card small{color:var(--muted)}
@keyframes loaderPulse{0%,100%{transform:scale(1);box-shadow:0 0 0 0 rgba(31,58,52,.24)}50%{transform:scale(1.04);box-shadow:0 0 0 16px rgba(31,58,52,0)}}

.topbar{background:#1D3557;color:#CFD3DB;font-size:14px}.topbar .container{display:flex;justify-content:space-between;gap:12px;padding:9px 0}.nav{position:sticky;top:0;z-index:50;background:rgba(246,239,227,.92);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-bottom:1px solid var(--line)}.nav-inner{display:flex;align-items:center;justify-content:space-between;gap:20px;padding:18px 0}.brand{display:inline-flex;align-items:center;gap:10px;font-weight:850;letter-spacing:-.03em}.brand-mark{display:inline-grid;place-items:center;width:36px;height:36px;border-radius:999px;background:var(--brand);color:#FFFFFF;font-size:22px}.menu{display:flex;align-items:center;gap:18px;font-size:15px}.menu a:not(.btn):hover{color:var(--brand2)}.nav-toggle{display:none;border:1px solid var(--line);background:var(--paper);border-radius:999px;padding:10px 15px;font-weight:800}.btn{display:inline-flex;align-items:center;justify-content:center;border:0;border-radius:999px;background:var(--brand);color:#FFFFFF;font-weight:800;padding:12px 20px;cursor:pointer;box-shadow:0 10px 30px rgba(31,58,52,.13);white-space:nowrap}.btn.light{background:var(--paper);color:var(--brand);border:1px solid var(--line);box-shadow:none}.btn.gold{background:var(--accent);color:#1D3557}.btn.danger{background:var(--danger)}

.hero{padding:72px 0 42px}.hero-editorial{background:radial-gradient(circle at 78% 18%,#A1A8B8 0,#CFD3DB 34%,transparent 58%)}.hero-grid{display:grid;grid-template-columns:1.08fr .92fr;gap:34px;align-items:center}.eyebrow,.tag{display:inline-flex;align-items:center;border:1px solid var(--line);background:rgba(255,250,242,.76);border-radius:999px;padding:6px 11px;color:var(--brand2);font-size:13px;font-weight:800}.hero h1{font-size:clamp(42px,7vw,82px);line-height:.95;letter-spacing:-.075em;margin:18px 0}.lead{font-size:clamp(18px,2vw,22px);color:#4A5976;max-width:780px}.hero-actions,.pill-list{display:flex;gap:12px;flex-wrap:wrap;margin-top:22px}.pill{border:1px solid var(--line);background:#FFFFFF;border-radius:999px;padding:8px 12px;color:#757F97}.hero-card,.card,.panel{background:var(--paper);border:1px solid var(--line);border-radius:30px;box-shadow:var(--shadow)}.hero-card{padding:32px;min-height:420px;display:flex;flex-direction:column;justify-content:space-between}.feature-stack h2{font-size:42px;line-height:1.05;letter-spacing:-.05em;margin:18px 0}.stat-row{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}.stat{background:#CFD3DB;border:1px solid var(--line);border-radius:22px;padding:16px}.stat b{display:block;font-size:28px}.stat span{font-size:13px;color:var(--muted)}

.section{padding:54px 0}.muted-section,.content-strip{background:rgba(255,250,242,.42);border-block:1px solid rgba(226,212,191,.55)}.section-head{display:flex;justify-content:space-between;align-items:end;gap:20px;margin-bottom:22px}.section-head h2,.content h1,.content h2{letter-spacing:-.05em;line-height:1.05}.section-head h2{font-size:clamp(30px,4vw,52px);margin:0}.sub{color:var(--muted);margin:.3rem 0 0}.head-actions{display:flex;align-items:center;gap:12px;flex-wrap:wrap;justify-content:flex-end}.grid{display:grid;gap:18px}.cols-2{grid-template-columns:repeat(2,1fr)}.cols-3{grid-template-columns:repeat(3,1fr)}.cols-4{grid-template-columns:repeat(4,1fr)}.card{display:block;padding:24px;transition:.24s transform,.24s box-shadow}.card:hover{transform:translateY(-3px);box-shadow:0 24px 70px rgba(54,34,15,.12)}.editorial-card h3,.service-card h3,.card h3{font-size:24px;line-height:1.12;margin:15px 0 8px}.card p{color:var(--muted);display:-webkit-box;display:box;-webkit-line-clamp:5;line-clamp:5;-webkit-box-orient:vertical;box-orient:vertical;overflow:hidden}.card small,.meta-row{color:var(--muted);font-size:13px}.empty{padding:22px;background:var(--paper);border:1px dashed var(--line);border-radius:22px}

.horizontal-rail{display:flex;gap:18px;overflow-x:auto;overflow-y:hidden;scroll-snap-type:x proximity;scroll-padding:20px;padding:4px 2px 22px;margin-inline:-2px}.horizontal-rail::-webkit-scrollbar{height:9px}.horizontal-rail::-webkit-scrollbar-track{background:rgba(226,212,191,.45);border-radius:999px}.horizontal-rail::-webkit-scrollbar-thumb{background:rgba(31,58,52,.34);border-radius:999px}.horizontal-rail.is-dragging{cursor:grabbing;scroll-snap-type:none}.rail-card{flex:0 0 min(360px,82vw);scroll-snap-align:start;min-height:295px}.service-rail .rail-card{flex-basis:min(390px,84vw)}.article-rail .rail-card{flex-basis:min(340px,82vw)}.rail-controls{display:inline-flex;gap:8px}.rail-controls button{width:42px;height:42px;border:1px solid var(--line);border-radius:12px;background:#CFD3DB;color:#4A5976;font-size:22px;line-height:1;cursor:pointer;transition:.18s transform,.18s opacity}.rail-controls button:hover{transform:translateY(-1px)}.rail-controls button:disabled{opacity:.35;cursor:not-allowed;transform:none}

.premium-video-section{background:linear-gradient(180deg,rgba(255,250,242,.52),rgba(246,239,227,0))}.video-showcase{display:grid;grid-template-columns:minmax(0,1fr) minmax(220px,390px);gap:18px;align-items:stretch}.feature-video{position:relative;min-height:460px;border:0;border-radius:32px;overflow:hidden;background:linear-gradient(135deg,#4A5976,#4A5976);padding:0;color:#FFFFFF;cursor:pointer;text-align:left;box-shadow:var(--shadow-strong);isolation:isolate}.feature-video:disabled{cursor:not-allowed}.feature-video-media,.feature-video-fallback{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}.feature-video-media{filter:saturate(1.02) contrast(1.02)}.feature-video::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(10,17,28,.05),rgba(10,17,28,.18) 42%,rgba(10,17,28,.82));z-index:1}.feature-shine{position:absolute;inset:-35%;z-index:2;background:linear-gradient(120deg,transparent 20%,rgba(255,255,255,.22) 45%,transparent 68%);transform:translateX(-55%) rotate(6deg);animation:videoShine 7s ease-in-out infinite}.feature-copy{position:absolute;left:26px;right:26px;bottom:26px;z-index:3;display:grid;gap:8px}.feature-copy strong{font-size:clamp(28px,4vw,46px);line-height:1;letter-spacing:-.05em}.feature-copy small{font-size:16px;color:rgba(255,255,255,.82);max-width:720px}.play-badge{position:absolute;top:22px;left:22px;z-index:3;border:1px solid rgba(255,255,255,.32);background:rgba(255,255,255,.14);-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);border-radius:999px;padding:9px 13px;font-size:13px;font-weight:850}.video-strip{display:flex;flex-direction:column;overflow-y:hidden;overflow-x:hidden;padding:0;margin:0;scroll-snap-type:y proximity}.video-thumb{position:relative;min-height:104px;border:0;border-radius:22px;overflow:hidden;background:#4A5976;color:#FFFFFF;padding:0;cursor:pointer;box-shadow:0 10px 26px rgba(21,28,38,.12);opacity:.72;transition:.22s opacity,.22s transform,.22s box-shadow}.video-thumb img{width:100%;height:100%;object-fit:cover}.video-thumb span{display:grid;place-items:center;min-height:104px;padding:14px;font-weight:900}.video-thumb::after{content:"";position:absolute;inset:0;border:3px solid transparent;border-radius:22px;transition:.2s border-color}.video-thumb.is-active,.video-thumb:hover{opacity:1;transform:translateX(-4px);box-shadow:0 18px 45px rgba(21,28,38,.22)}.video-thumb.is-active::after{border-color:#FFFFFF}.video-lightbox{position:fixed;inset:0;z-index:9998;background:rgba(10,17,28,.72);-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);display:grid;place-items:center;padding:24px;opacity:0;visibility:hidden;pointer-events:none;transition:.28s opacity,.28s visibility}.video-lightbox.is-open{opacity:1;visibility:visible;pointer-events:auto}.lightbox-shell{width:min(1100px,100%);max-height:calc(100vh - 48px);display:grid;gap:14px}.lightbox-shell video{width:100%;max-height:min(74vh,760px);background:#000000;border-radius:28px;box-shadow:0 30px 110px rgba(0,0,0,.34)}.lightbox-copy{color:#FFFFFF}.lightbox-copy strong{font-size:28px}.lightbox-copy p{color:rgba(255,255,255,.75);margin:.25rem 0 0}.lightbox-close{position:fixed;top:18px;right:18px;width:48px;height:48px;border:1px solid rgba(255,255,255,.24);border-radius:999px;background:rgba(255,255,255,.12);color:#FFFFFF;font-size:34px;line-height:1;cursor:pointer;z-index:2}
@keyframes videoShine{0%,30%{transform:translateX(-70%) rotate(6deg)}55%,100%{transform:translateX(70%) rotate(6deg)}}

.reviews-premium{position:relative;overflow:hidden;background:linear-gradient(180deg,rgba(255,250,242,.78) 0,rgba(246,239,227,.96) 100%);color:var(--ink);padding-bottom:42px;isolation:isolate}.reviews-premium::before{content:"";position:absolute;inset:0;background:radial-gradient(circle at 12% 8%,rgba(196,135,75,.16),transparent 32%),radial-gradient(circle at 86% 18%,rgba(31,58,52,.11),transparent 34%),linear-gradient(120deg,rgba(255,250,242,.46),rgba(255,250,242,0));z-index:-2}.reviews-premium::after{content:"";position:absolute;left:50%;bottom:-160px;width:min(980px,92vw);height:330px;transform:translateX(-50%);border-radius:50%;background:radial-gradient(circle,rgba(31,58,52,.12),rgba(196,135,75,.09) 35%,rgba(255,250,242,0) 68%);filter:blur(10px);z-index:-1;pointer-events:none}.reviews-premium .container{position:relative;z-index:1}.reviews-premium .section-head h2{color:var(--ink)}.reviews-premium .sub{color:var(--muted);max-width:720px}.reviews{display:flex;gap:18px}.review-rail{padding-bottom:24px}.review-card{position:relative;flex:0 0 min(380px,86vw);min-height:238px;color:var(--ink);scroll-snap-align:start;background:rgba(255,250,242,.92);border-color:rgba(226,212,191,.88);box-shadow:0 18px 54px rgba(54,34,15,.08);overflow:hidden;transform-origin:center bottom}.review-card::before{content:"";position:absolute;inset:0 0 auto;height:4px;background:linear-gradient(90deg,var(--brand),rgba(196,135,75,.72),rgba(31,58,52,.08));opacity:.8}.review-card::after{content:"";position:absolute;right:-58px;bottom:-68px;width:155px;height:155px;border-radius:50%;background:radial-gradient(circle,rgba(196,135,75,.12),rgba(196,135,75,0) 68%);pointer-events:none}.review-card:hover,.review-card:focus-within{transform:translateY(-6px);box-shadow:0 26px 78px rgba(54,34,15,.13)}.review-card blockquote{margin:14px 0 18px;color:#4A5976;font-size:17px;line-height:1.7}.review-card figcaption{display:grid;gap:2px}.stars{color:#4A5976;letter-spacing:2px}.review-trust-note{margin:10px 0 0;padding:18px 20px;border:1px solid rgba(31,58,52,.12);border-radius:24px;background:rgba(255,250,242,.78);box-shadow:0 16px 48px rgba(54,34,15,.06);display:grid;gap:4px;max-width:820px}.review-trust-note span{font-weight:850;letter-spacing:-.02em;color:var(--brand)}.review-trust-note small{color:var(--muted);line-height:1.55}

.split{display:grid;grid-template-columns:280px 1fr;gap:34px;align-items:start}.toc{position:sticky;top:94px;background:var(--paper);border:1px solid var(--line);border-radius:26px;padding:18px;display:flex;flex-direction:column;gap:10px}.toc strong{font-size:18px}.toc a{color:var(--muted);font-size:14px;padding:8px;border-radius:12px}.toc a:hover{background:#CFD3DB;color:var(--ink)}.content{background:var(--paper);border:1px solid var(--line);border-radius:34px;padding:38px}.content h1{font-size:clamp(38px,5vw,68px);margin:16px 0}.content h2{font-size:34px;margin-top:42px}.breadcrumb{color:var(--muted);font-size:14px;margin-bottom:14px}.notice{background:#FFFFFF;border:1px solid #A1A8B8;border-radius:20px;padding:14px 16px;margin:22px 0}.cover{border-radius:28px;margin:24px 0;width:100%;max-height:420px;object-fit:cover}.meta-row{display:flex;gap:12px;flex-wrap:wrap;margin:16px 0}.check-list li{margin:7px 0}.faq-list details{border:1px solid var(--line);border-radius:18px;padding:14px 16px;margin:10px 0;background:#FFFFFF}.faq-list summary{font-weight:850;cursor:pointer}.cta-band{background:linear-gradient(135deg,var(--brand),#4A5976);color:#FFFFFF;border-radius:34px;padding:32px;display:flex;align-items:center;justify-content:space-between;gap:20px}.cta-band p{color:#CFD3DB}.form{display:grid;gap:14px}.form label{display:grid;gap:6px;font-weight:800}.input,.textarea,.select{width:100%;border:1px solid var(--line);border-radius:16px;padding:13px 14px;background:#FFFFFF;color:var(--ink);font:inherit}.textarea{min-height:130px;resize:vertical}.tall{min-height:260px}.checkline{display:flex!important;align-items:flex-start;grid-template-columns:auto 1fr;gap:10px;font-weight:600!important}.hidden-field{position:absolute;left:-9999px}.field-error{color:var(--danger)}.alert{padding:14px 16px;border-radius:18px;margin:12px 0}.alert.success{background:#FFFFFF;border:1px solid #CFD3DB}.alert.error{background:#FFFFFF;border:1px solid #A1A8B8}.map iframe{width:100%;min-height:340px;border:0;border-radius:28px}.footer{background:#1D3557;color:#CFD3DB;margin-top:52px;padding:44px 0}.footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:24px}.footer a{display:block;color:#CFD3DB;margin:7px 0}.microcopy{font-size:13px;color:#A1A8B8}

.pagination,nav[role="navigation"]{margin:32px 0 8px}nav[role="navigation"] svg{width:20px;height:20px}nav[role="navigation"] a,nav[role="navigation"] span{max-width:100%}.site-pagination{margin:36px 0 10px;display:flex;align-items:center;justify-content:center;gap:14px;flex-wrap:wrap}.site-pagination .page-btn{display:inline-flex;align-items:center;justify-content:center;min-width:96px;height:42px;padding:0 18px;border-radius:999px;background:var(--brand);color:#FFFFFF;text-decoration:none;font-weight:700;font-size:14px;line-height:1;border:1px solid transparent}.site-pagination .page-btn.disabled{background:#CFD3DB;color:#757F97;cursor:not-allowed}.site-pagination .page-info{font-size:14px;font-weight:700;color:var(--muted);background:var(--paper);border:1px solid rgba(31,58,52,.12);border-radius:999px;padding:12px 16px}

.reveal-up{opacity:0;transform:translateY(24px);transition:opacity .64s ease,transform .64s cubic-bezier(.2,.8,.2,1);transition-delay:var(--reveal-delay,0ms)}.reveal-up.is-visible{opacity:1;transform:translateY(0)}

@media(max-width:1100px){.video-showcase{grid-template-columns:1fr}.video-strip{flex-direction:row;overflow-x:auto;scroll-snap-type:x proximity}.video-thumb{flex:0 0 180px;min-height:136px}.video-thumb:hover,.video-thumb.is-active{transform:translateY(-3px)}.feature-video{min-height:420px}}
@media(max-width:960px){.hero-grid,.split,.cols-3,.cols-4,.footer-grid{grid-template-columns:1fr}.cols-2{grid-template-columns:1fr}.section-head{align-items:start;flex-direction:column}.head-actions{justify-content:flex-start}.menu{display:none;position:absolute;top:74px;left:20px;right:20px;background:var(--paper);border:1px solid var(--line);border-radius:26px;padding:18px;flex-direction:column;align-items:stretch;box-shadow:var(--shadow)}.menu.is-open{display:flex}.nav-toggle{display:inline-flex}.toc{position:static}.topbar .container{flex-direction:column}.stat-row{grid-template-columns:1fr}.content{padding:24px}.hero{padding:44px 0 26px}.rail-card{flex-basis:min(330px,84vw)}}
@media(max-width:720px){.section{padding:42px 0}.feature-video{min-height:360px;border-radius:26px}.feature-copy{left:18px;right:18px;bottom:18px}.play-badge{top:16px;left:16px}.video-thumb{flex-basis:150px;min-height:120px}.review-card{min-height:220px}.review-trust-note{padding:16px;border-radius:20px}}
@media(max-width:620px){.container{width:min(100% - 24px,1180px)}.hero h1{font-size:44px}.feature-stack h2{font-size:32px}.cta-band{align-items:flex-start;flex-direction:column}.btn{width:100%;white-space:normal}.nav-inner{padding:12px 0}.content h2{font-size:28px}.section-head .btn{width:auto}.rail-controls button{width:40px;height:40px}.horizontal-rail{gap:14px;margin-inline:-12px;padding-left:12px;padding-right:12px}.rail-card{flex:0 0 86vw}.feature-video{min-height:330px}.feature-copy strong{font-size:30px}.feature-copy small{font-size:14px}.lightbox-shell video{border-radius:20px}.lightbox-close{width:44px;height:44px}.topbar{font-size:13px}.brand span:last-child{max-width:210px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.site-pagination .page-info{order:-1;width:100%;text-align:center}}
@media(max-width:430px){.hero h1{font-size:38px}.hero-card{min-height:unset;padding:24px}.feature-video{min-height:300px}.video-thumb{flex-basis:132px;min-height:104px}.review-card{flex-basis:88vw}.footer{padding:34px 0}.loader-card{padding:24px}}
@media(prefers-reduced-motion:reduce){html{scroll-behavior:auto}.loader-mark,.feature-shine{animation:none}.reveal-up{opacity:1;transform:none;transition:none}.card,.rail-controls button,.video-thumb{transition:none}}
/* Stage 1 premium motion system: calm micro-interactions, no particle/canvas effects. */
body {
    background:
        radial-gradient(circle at 8% 8%, rgba(196, 135, 75, .10), transparent 26%),
        radial-gradient(circle at 92% 12%, rgba(31, 58, 52, .08), transparent 30%),
        linear-gradient(180deg, var(--bg) 0%, #CFD3DB 46%, var(--bg) 100%);
}

#main-content {
    position: relative;
    z-index: 1;
}

body::before {
    content: "";
    position: fixed;
    inset: 0;
    z-index: -1;
    pointer-events: none;
    background:
        linear-gradient(90deg, rgba(255, 250, 242, .34), transparent 24%, transparent 76%, rgba(255, 250, 242, .28)),
        radial-gradient(circle at 50% 0%, rgba(255, 250, 242, .42), transparent 46%);
}

.hero-editorial {
    position: relative;
    overflow: hidden;
    background:
        radial-gradient(circle at 76% 20%, rgba(229, 195, 153, .86) 0, rgba(246, 239, 227, .86) 32%, transparent 58%),
        linear-gradient(180deg, rgba(255, 250, 242, .32), rgba(246, 239, 227, 0));
}

.hero-editorial::after {
    content: "";
    position: absolute;
    right: max(-120px, -8vw);
    top: 18%;
    width: min(520px, 62vw);
    height: min(520px, 62vw);
    border-radius: 999px;
    background: radial-gradient(circle, rgba(31, 58, 52, .10), rgba(196, 135, 75, .08) 38%, transparent 72%);
    filter: blur(18px);
    pointer-events: none;
}

.hero-editorial .container {
    position: relative;
    z-index: 1;
}

.btn,
.card,
.video-thumb,
.feature-video,
.review-card,
.nav-toggle,
.menu a:not(.btn) {
    -webkit-tap-highlight-color: transparent;
}

.btn {
    position: relative;
    overflow: hidden;
    transition: transform .22s ease, box-shadow .22s ease, background-color .22s ease, border-color .22s ease;
}

.btn::after {
    content: "";
    position: absolute;
    inset: -55% -35%;
    background: linear-gradient(110deg, transparent 28%, rgba(255, 255, 255, .26) 45%, transparent 62%);
    transform: translateX(-70%) rotate(7deg);
    opacity: 0;
    pointer-events: none;
    transition: transform .7s cubic-bezier(.2, .8, .2, 1), opacity .25s ease;
}

.btn:hover,
.btn:focus-visible {
    transform: translateY(-1px);
    box-shadow: 0 16px 38px rgba(31, 58, 52, .18);
}

.btn:hover::after,
.btn:focus-visible::after {
    opacity: 1;
    transform: translateX(70%) rotate(7deg);
}

.btn.light:hover,
.btn.light:focus-visible {
    border-color: rgba(196, 135, 75, .55);
    box-shadow: 0 14px 32px rgba(54, 34, 15, .08);
}

.btn.gold:hover,
.btn.gold:focus-visible {
    box-shadow: 0 16px 38px rgba(196, 135, 75, .24);
}

.menu a:not(.btn) {
    position: relative;
    transition: color .2s ease;
}

.menu a:not(.btn)::after {
    content: "";
    position: absolute;
    left: 0;
    right: 100%;
    bottom: -8px;
    height: 2px;
    border-radius: 999px;
    background: linear-gradient(90deg, var(--brand), var(--accent));
    transition: right .24s ease;
}

.menu a:not(.btn):hover::after,
.menu a:not(.btn):focus-visible::after {
    right: 0;
}

.card {
    position: relative;
    overflow: hidden;
    transform: translateZ(0);
    transition: transform .24s cubic-bezier(.2, .8, .2, 1), box-shadow .24s ease, border-color .24s ease, background-color .24s ease;
}

.card::before {
    content: "";
    position: absolute;
    inset: 0 0 auto;
    height: 3px;
    background: linear-gradient(90deg, rgba(31, 58, 52, .82), rgba(196, 135, 75, .64), rgba(31, 58, 52, 0));
    opacity: 0;
    transition: opacity .24s ease;
}

.card:hover,
.card:focus-visible,
.card:focus-within {
    transform: translateY(-4px);
    border-color: rgba(196, 135, 75, .42);
    box-shadow: 0 24px 74px rgba(54, 34, 15, .12);
}

.card:hover::before,
.card:focus-visible::before,
.card:focus-within::before {
    opacity: .85;
}

.hero-card:hover {
    transform: translateY(-3px);
    box-shadow: 0 24px 72px rgba(54, 34, 15, .10);
}

.rail-controls button {
    background: rgba(255, 250, 242, .86);
    color: var(--brand);
    box-shadow: 0 10px 26px rgba(54, 34, 15, .06);
}

.rail-controls button:hover,
.rail-controls button:focus-visible {
    border-color: rgba(196, 135, 75, .58);
    color: var(--brand2);
    background: #FFFFFF;
}

.horizontal-rail {
}

.review-card blockquote {
    overflow-wrap: break-word;
word-break: normal;
}

.cta-band {
    position: relative;
    overflow: hidden;
    box-shadow: 0 26px 80px rgba(31, 58, 52, .17);
}

.cta-band::before {
    content: "";
    position: absolute;
    inset: -40% auto auto 52%;
    width: 420px;
    height: 420px;
    border-radius: 999px;
    background: radial-gradient(circle, rgba(255, 250, 242, .16), transparent 68%);
    pointer-events: none;
}

.cta-band > * {
    position: relative;
    z-index: 1;
}

:focus-visible {
    outline: 3px solid rgba(196, 135, 75, .62);
    outline-offset: 4px;
}

.reveal-up {
    will-change: opacity, transform;
}

@media (max-width: 960px) {
    .hero-editorial::after {
        opacity: .55;
        right: -180px;
    }

    .menu a:not(.btn)::after {
        display: none;
    }
}

@media (max-width: 620px) {
    body::before {
        opacity: .64;
    }

    .card:hover,
    .card:focus-visible,
    .card:focus-within,
    .hero-card:hover,
    .btn:hover,
    .btn:focus-visible {
        transform: none;
    }

    .btn::after {
        display: none;
    }
}

@media (prefers-reduced-motion: reduce) {
    *,
    *::before,
    *::after {
        scroll-behavior: auto !important;
    }

    .btn::after,
    .card::before,
    .cta-band::before,
    .hero-editorial::after {
        transition: none !important;
        animation: none !important;
    }
}

/* Stage 1.1 — full-edge card accent + premium looping review motion. */
.card,
.review-card {
    isolation: isolate;
}

.card::before,
.review-card::before {
    content: "";
    position: absolute;
    inset: 0;
    height: auto;
    border-radius: inherit;
    pointer-events: none;
    opacity: 0;
    background:
        linear-gradient(135deg,
            rgba(31, 58, 52, .72),
            rgba(196, 135, 75, .46) 38%,
            rgba(31, 58, 52, .28) 72%,
            rgba(31, 58, 52, .66)
        );
    box-shadow:
        inset 0 0 0 1px rgba(31, 58, 52, .18),
        inset 0 0 0 2px rgba(196, 135, 75, .06);
    -webkit-mask:
        linear-gradient(#000000 0 0) content-box,
        linear-gradient(#000000 0 0);
    -webkit-mask-composite: xor;
    mask:
        linear-gradient(#000000 0 0) content-box,
        linear-gradient(#000000 0 0);
    mask-composite: exclude;
    padding: 1px;
    transition: opacity .26s ease, box-shadow .26s ease;
    z-index: 0;
}

.card > *,
.review-card > * {
    position: relative;
    z-index: 1;
}

.card:hover::before,
.card:focus-visible::before,
.card:focus-within::before,
.review-card:hover::before,
.review-card:focus-visible::before,
.review-card:focus-within::before {
    opacity: .96;
}

.card:hover,
.card:focus-visible,
.card:focus-within,
.review-card:hover,
.review-card:focus-visible,
.review-card:focus-within {
    border-color: rgba(31, 58, 52, .24);
}

.reviews-premium {
    --review-motion-speed: 1;
}

.review-rail {
    position: relative;
    gap: 18px;
    cursor: grab;
    scroll-snap-type: none;
    scroll-behavior: auto;
    overscroll-behavior-x: contain;
    -webkit-user-select: none;
    user-select: none;
    padding-block: 6px 28px;
    margin-inline: max(-18px, calc((100vw - 1180px) / -2));
    padding-inline: max(18px, calc((100vw - 1180px) / 2 + 18px));
}

.review-rail.is-dragging {
    cursor: grabbing;
}

.review-rail.is-marquee-ready .review-card {
    scroll-snap-align: none;
}

.review-rail.is-marquee-paused .review-card {
    transition-duration: .18s;
}

.review-card {
    flex: 0 0 min(392px, 84vw);
    min-height: 246px;
    scroll-snap-align: none;
    transition:
        transform .28s cubic-bezier(.2, .8, .2, 1),
        box-shadow .28s ease,
        border-color .28s ease,
        background-color .28s ease;
}

.review-card::after {
    opacity: .85;
}

.review-card:not(.is-clone) {
    animation: reviewCardBreath 5.6s ease-in-out infinite alternate;
    animation-delay: var(--review-breath-delay, 0ms);
}

.review-card.is-clone {
    animation: none;
}

.review-rail:hover .review-card:not(:hover),
.review-rail:focus-within .review-card:not(:focus-within),
.review-rail.is-dragging .review-card {
    animation-play-state: paused;
}

.review-card:hover,
.review-card:focus-visible,
.review-card:focus-within {
    animation-play-state: paused;
    transform: translateY(-6px);
}

.review-rail::before,
.review-rail::after {
    content: "";
    position: sticky;
    top: 0;
    bottom: 0;
    z-index: 3;
    flex: 0 0 0;
    width: 0;
    pointer-events: none;
}

.reviews-premium .container::before,
.reviews-premium .container::after {
    content: "";
    position: absolute;
    top: 92px;
    bottom: 92px;
    width: min(120px, 14vw);
    z-index: 2;
    pointer-events: none;
}

.reviews-premium .container::before {
    left: 0;
    background: linear-gradient(90deg, rgba(247, 241, 231, .96), rgba(247, 241, 231, 0));
}

.reviews-premium .container::after {
    right: 0;
    background: linear-gradient(270deg, rgba(247, 241, 231, .96), rgba(247, 241, 231, 0));
}

@keyframes reviewCardBreath {
    0% {
        transform: translateY(0);
        box-shadow: 0 18px 54px rgba(54, 34, 15, .08);
    }

    100% {
        transform: translateY(-2px);
        box-shadow: 0 22px 62px rgba(54, 34, 15, .105);
    }
}

@media (max-width: 960px) {
    .review-rail {
        margin-inline: -20px;
        padding-inline: 20px;
    }

    .reviews-premium .container::before,
    .reviews-premium .container::after {
        width: 44px;
        top: 116px;
        bottom: 92px;
    }
}

@media (max-width: 620px) {
    .review-card {
        flex-basis: 86vw;
        min-height: 226px;
    }

    .review-rail {
        margin-inline: -12px;
        padding-inline: 12px;
        gap: 14px;
    }

    .reviews-premium .container::before,
    .reviews-premium .container::after {
        display: none;
    }

    .review-card:not(.is-clone) {
        animation: none;
    }
}

@media (prefers-reduced-motion: reduce) {
    .review-card,
    .review-card:not(.is-clone) {
        animation: none !important;
    }

    .card::before,
    .review-card::before {
        transition: none !important;
    }
}

/* Stage 1.2 — review rail layout fix: no broken left crop, visible loop, smooth premium motion. */
.reviews-premium {
    overflow: hidden;
}

.reviews-premium .container {
    overflow: visible;
}

.reviews-premium .section-head {
    position: relative;
    z-index: 4;
}

.reviews-premium .container::before,
.reviews-premium .container::after {
    display: none !important;
}

.review-rail {
    width: 100%;
    max-width: 100%;
    margin-inline: 0 !important;
    padding-inline: 0 !important;
    padding-block: 14px 30px;
    overflow-x: auto;
    overflow-y: visible;
    scroll-padding-inline: 0;
    -webkit-mask-image: linear-gradient(90deg, transparent 0, #000000 42px, #000000 calc(100% - 42px), transparent 100%);
    mask-image: linear-gradient(90deg, transparent 0, #000000 42px, #000000 calc(100% - 42px), transparent 100%);
}

.review-rail::before,
.review-rail::after {
    display: none !important;
}

.review-rail .review-card {
    flex: 0 0 clamp(320px, 31vw, 410px);
    min-width: clamp(320px, 31vw, 410px);
    margin: 0;
    opacity: 1;
    visibility: visible;
}

.review-rail.is-marquee-ready {
    scroll-snap-type: none;
}

.review-rail.is-marquee-ready .review-card {
    scroll-snap-align: none;
}

.review-rail.is-marquee-paused {
    cursor: grab;
}

.review-rail.is-dragging {
    cursor: grabbing;
}

.review-rail.is-dragging,
.review-rail.is-dragging * {
   -webkit-user-select: none;
    user-select: none;
}

.review-card:not(:hover):not(:focus-within) {
    animation: reviewCardBreath 5.8s ease-in-out infinite alternate;
    animation-delay: var(--review-breath-delay, 0ms);
}

.review-card.is-clone {
    animation-delay: var(--review-breath-delay, 0ms);
}

.review-rail:hover .review-card,
.review-rail:focus-within .review-card,
.review-rail.is-dragging .review-card {
    animation-play-state: paused;
}

.review-card:hover,
.review-card:focus-within {
    transform: translateY(-6px);
}

.review-trust-note {
    position: relative;
    z-index: 4;
}

@media (max-width: 960px) {
    .review-rail {
        -webkit-mask-image: linear-gradient(90deg, transparent 0, #000000 22px, #000000 calc(100% - 22px), transparent 100%);
        mask-image: linear-gradient(90deg, transparent 0, #000000 22px, #000000 calc(100% - 22px), transparent 100%);
    }

    .review-rail .review-card {
        flex-basis: min(360px, 78vw);
        min-width: min(360px, 78vw);
    }
}

@media (max-width: 620px) {
    .review-rail {
        gap: 14px;
        -webkit-mask-image: none;
        mask-image: none;
        padding-bottom: 24px;
    }

    .review-rail .review-card {
        flex-basis: 84vw;
        min-width: 84vw;
    }

    .review-card:not(:hover):not(:focus-within) {
        animation: none;
    }
}

@media (prefers-reduced-motion: reduce) {
    .review-card:not(:hover):not(:focus-within),
    .review-card.is-clone {
        animation: none !important;
    }
}

/* Stage 1.3 — review rail curtain removal + visible autonomous motion. */
.reviews-premium {
    overflow: hidden;
    background:
        radial-gradient(circle at 18% 8%, rgba(196, 135, 75, .11), transparent 30%),
        radial-gradient(circle at 82% 14%, rgba(31, 58, 52, .075), transparent 32%),
        linear-gradient(180deg, rgba(255, 250, 242, .84) 0%, rgba(246, 239, 227, .94) 100%);
}

.reviews-premium .container {
    overflow: visible;
}

.reviews-premium .container::before,
.reviews-premium .container::after,
.review-rail::before,
.review-rail::after {
    display: none !important;
    content: none !important;
}

.review-rail {
    width: 100%;
    max-width: 100%;
    margin-inline: 0 !important;
    padding: 12px 0 28px !important;
    background: transparent !important;
    overflow-x: auto;
    overflow-y: visible;
    scroll-padding-inline: 0;
    scroll-snap-type: none;
    -webkit-mask-image: none !important;
    mask-image: none !important;
    cursor: grab;
}

.review-rail.is-dragging {
    cursor: grabbing;
}

.review-rail .review-card {
    flex: 0 0 clamp(326px, 31vw, 414px);
    min-width: clamp(326px, 31vw, 414px);
    opacity: 1 !important;
    visibility: visible !important;
    filter: none !important;
    scroll-snap-align: none;
}

.review-rail .review-card.is-clone {
    pointer-events: none;
}

.review-card {
    background: rgba(255, 250, 242, .97);
    border-color: rgba(31, 58, 52, .14);
}

.review-card::before {
    opacity: .42;
}

.review-card:hover::before,
.review-card:focus-visible::before,
.review-card:focus-within::before {
    opacity: .92;
}

.review-rail.is-marquee-ready .review-card:not(:hover):not(:focus-within) {
    animation: reviewCardBreath 5.8s ease-in-out infinite alternate;
    animation-delay: var(--review-breath-delay, 0ms);
}

.review-rail:hover .review-card,
.review-rail:focus-within .review-card,
.review-rail.is-dragging .review-card {
    animation-play-state: paused;
}

.review-rail:hover,
.review-rail:focus-within,
.review-rail.is-dragging {
    scroll-behavior: auto;
}

@media (max-width: 960px) {
    .review-rail {
        padding-bottom: 24px !important;
    }

    .review-rail .review-card {
        flex-basis: min(360px, 78vw);
        min-width: min(360px, 78vw);
    }
}

@media (max-width: 620px) {
    .review-rail {
        gap: 14px;
        padding-bottom: 22px !important;
    }

    .review-rail .review-card {
        flex-basis: 84vw;
        min-width: 84vw;
    }

    .review-rail.is-marquee-ready .review-card:not(:hover):not(:focus-within) {
        animation: none;
    }
}

/* Stage 1.4 — soft edge-light for every horizontal rail.
   Amaç: yatay kayan alanların sert kutu içinde bitiyor hissini kırmak.
   Not: Bu katman dekoratif; içerik HTML olarak kaldığı için SEO ve okunabilirlik korunur. */
.horizontal-rail {
    --rail-edge-light-size: clamp(34px, 6vw, 82px);
    --rail-edge-light-rgb: 255, 250, 242;
    --rail-edge-light-opacity: .94;
    position: relative;
    isolation: isolate;
}

.horizontal-rail.has-edge-light::before,
.horizontal-rail.has-edge-light::after {
    content: "";
    position: sticky;
    top: 0;
    bottom: 0;
    align-self: stretch;
    flex: 0 0 var(--rail-edge-light-size);
    min-height: 100%;
    z-index: 5;
    pointer-events: none;
    opacity: var(--rail-edge-light-opacity);
    transition: opacity .22s ease, filter .22s ease;
}

.horizontal-rail.has-edge-light::before {
    left: 0;
    margin-right: calc(var(--rail-edge-light-size) * -1);
    background:
        radial-gradient(ellipse at left center,
            rgba(255, 255, 255, .72) 0%,
            rgba(var(--rail-edge-light-rgb), .58) 28%,
            rgba(var(--rail-edge-light-rgb), .24) 62%,
            rgba(var(--rail-edge-light-rgb), 0) 100%),
        linear-gradient(90deg,
            rgba(var(--rail-edge-light-rgb), .94) 0%,
            rgba(var(--rail-edge-light-rgb), .66) 26%,
            rgba(var(--rail-edge-light-rgb), .24) 62%,
            rgba(var(--rail-edge-light-rgb), 0) 100%);
}

.horizontal-rail.has-edge-light::after {
    right: 0;
    margin-left: calc(var(--rail-edge-light-size) * -1);
    background:
        radial-gradient(ellipse at right center,
            rgba(255, 255, 255, .72) 0%,
            rgba(var(--rail-edge-light-rgb), .58) 28%,
            rgba(var(--rail-edge-light-rgb), .24) 62%,
            rgba(var(--rail-edge-light-rgb), 0) 100%),
        linear-gradient(270deg,
            rgba(var(--rail-edge-light-rgb), .94) 0%,
            rgba(var(--rail-edge-light-rgb), .66) 26%,
            rgba(var(--rail-edge-light-rgb), .24) 62%,
            rgba(var(--rail-edge-light-rgb), 0) 100%);
}

.horizontal-rail.has-edge-light.is-at-start::before,
.horizontal-rail.has-edge-light.is-at-end::after {
    opacity: .58;
}

.horizontal-rail.has-edge-light:not(.is-at-start)::before,
.horizontal-rail.has-edge-light:not(.is-at-end)::after {
    filter: drop-shadow(0 0 18px rgba(255, 250, 242, .62));
}

.review-rail {
    --rail-edge-light-size: clamp(38px, 6.2vw, 86px);
    --rail-edge-light-rgb: 255, 250, 242;
    --rail-edge-light-opacity: .88;
}

.card-rail {
    --rail-edge-light-rgb: 247, 241, 231;
}

.article-rail,
.service-rail {
    --rail-edge-light-opacity: .90;
}

.video-strip.horizontal-rail {
    --rail-edge-light-size: clamp(26px, 4vw, 54px);
    --rail-edge-light-rgb: 255, 250, 242;
    --rail-edge-light-opacity: .72;
}

.video-strip.horizontal-rail.has-edge-light::before,
.video-strip.horizontal-rail.has-edge-light::after {
    border-radius: 22px;
}

.horizontal-rail.is-dragging::before,
.horizontal-rail.is-dragging::after {
    opacity: .42;
}

@media (max-width: 720px) {
    .horizontal-rail {
        --rail-edge-light-size: 34px;
        --rail-edge-light-opacity: .78;
    }

    .review-rail {
        --rail-edge-light-size: 38px;
        --rail-edge-light-opacity: .76;
    }
}

@media (max-width: 430px) {
    .horizontal-rail {
        --rail-edge-light-size: 24px;
        --rail-edge-light-opacity: .62;
    }
}

@media (prefers-reduced-motion: reduce) {
    .horizontal-rail.has-edge-light::before,
    .horizontal-rail.has-edge-light::after {
        transition: none;
        filter: none;
    }
}

/* Stage 1.5 — smooth rail system without curtain overlays.
   Amaç: yatay kayan alanların önüne perde bindirmeden, kutunun kendi yüzeyinde yumuşak kenar ışığı vermek.
   SEO/okunabilirlik: içerik HTML olarak kalır; pseudo overlay metin/kartların üstüne çıkmaz. */
.horizontal-rail {
    --rail-surface: rgba(255, 250, 242, .28);
    --rail-surface-strong: rgba(255, 250, 242, .62);
    --rail-edge-glow: rgba(255, 250, 242, .88);
    --rail-edge-glow-soft: rgba(246, 239, 227, .58);
    position: relative;
    z-index: 0;
    isolation: isolate;
    scroll-behavior: auto !important;
    overscroll-behavior-x: contain;
    transform: translateZ(0);
    border-radius: 34px;
    background:
        radial-gradient(ellipse at left center,
            var(--rail-edge-glow) 0%,
            var(--rail-edge-glow-soft) 22%,
            rgba(255, 250, 242, .18) 48%,
            rgba(255, 250, 242, 0) 74%),
        radial-gradient(ellipse at right center,
            var(--rail-edge-glow) 0%,
            var(--rail-edge-glow-soft) 22%,
            rgba(255, 250, 242, .18) 48%,
            rgba(255, 250, 242, 0) 74%),
        linear-gradient(90deg,
            var(--rail-surface-strong),
            var(--rail-surface) 14%,
            rgba(255, 250, 242, .06) 50%,
            var(--rail-surface) 86%,
            var(--rail-surface-strong));
    box-shadow:
        inset 34px 0 38px -42px rgba(255, 255, 255, .96),
        inset -34px 0 38px -42px rgba(255, 255, 255, .96);
}

.horizontal-rail.has-edge-light::before,
.horizontal-rail.has-edge-light::after,
.horizontal-rail::before,
.horizontal-rail::after,
.review-rail::before,
.review-rail::after,
.reviews-premium .container::before,
.reviews-premium .container::after {
    display: none !important;
    content: none !important;
}

.horizontal-rail > * {
    position: relative;
    z-index: 1;
}

.horizontal-rail.is-scrollable:not(.is-at-start) {
    box-shadow:
        inset 42px 0 46px -46px rgba(255, 255, 255, .98),
        inset -34px 0 38px -42px rgba(255, 255, 255, .92),
        -18px 0 52px -38px rgba(255, 250, 242, .88);
}

.horizontal-rail.is-scrollable:not(.is-at-end) {
    box-shadow:
        inset 34px 0 38px -42px rgba(255, 255, 255, .92),
        inset -42px 0 46px -46px rgba(255, 255, 255, .98),
        18px 0 52px -38px rgba(255, 250, 242, .88);
}

.horizontal-rail.is-scrollable:not(.is-at-start):not(.is-at-end) {
    box-shadow:
        inset 42px 0 46px -46px rgba(255, 255, 255, .98),
        inset -42px 0 46px -46px rgba(255, 255, 255, .98),
        -18px 0 52px -38px rgba(255, 250, 242, .88),
        18px 0 52px -38px rgba(255, 250, 242, .88);
}

.horizontal-rail.is-dragging {
    cursor: grabbing;
    scroll-snap-type: none !important;
    -webkit-user-select: none;
    user-select: none;
}

.horizontal-rail.is-dragging *,
.horizontal-rail.is-smooth-scrolling * {
    pointer-events: none;
}

.horizontal-rail.is-smooth-scrolling,
.review-rail.is-marquee-ready {
    scroll-snap-type: none !important;
}

.service-rail,
.article-rail,
.card-rail {
    padding-top: 10px;
    padding-bottom: 24px;
}

.review-rail {
    --rail-surface: rgba(255, 250, 242, .20);
    --rail-surface-strong: rgba(255, 250, 242, .48);
    --rail-edge-glow: rgba(255, 250, 242, .82);
    --rail-edge-glow-soft: rgba(246, 239, 227, .42);
    padding: 16px 0 30px !important;
    background:
        radial-gradient(ellipse at left center,
            rgba(255, 255, 255, .54) 0%,
            rgba(255, 250, 242, .28) 26%,
            rgba(255, 250, 242, 0) 72%),
        radial-gradient(ellipse at right center,
            rgba(255, 255, 255, .54) 0%,
            rgba(255, 250, 242, .28) 26%,
            rgba(255, 250, 242, 0) 72%),
        linear-gradient(90deg,
            rgba(255, 250, 242, .18),
            rgba(255, 250, 242, .04) 22%,
            rgba(255, 250, 242, .04) 78%,
            rgba(255, 250, 242, .18));
    box-shadow: none;
    will-change: scroll-position;
}

.review-rail .review-card {
    transform: translateZ(0);
    will-change: transform;
    backface-visibility: hidden;
}

.review-rail.is-marquee-ready:not(:hover):not(:focus-within):not(.is-dragging) .review-card:not(.is-clone) {
    animation: reviewCardBreath 6.2s ease-in-out infinite alternate;
    animation-delay: var(--review-breath-delay, 0ms);
}

.review-rail.is-marquee-paused .review-card,
.review-rail.is-dragging .review-card,
.review-rail:hover .review-card,
.review-rail:focus-within .review-card {
    animation-play-state: paused !important;
}

.rail-controls button {
    transition:
        transform .2s cubic-bezier(.2, .8, .2, 1),
        opacity .2s ease,
        box-shadow .2s ease,
        border-color .2s ease;
}

.rail-controls button:not(:disabled):hover,
.rail-controls button:not(:disabled):focus-visible {
    transform: translateY(-2px);
    border-color: rgba(196, 135, 75, .48);
    box-shadow: 0 14px 34px rgba(54, 34, 15, .10);
}

@media (max-width: 720px) {
    .horizontal-rail {
        border-radius: 26px;
        background:
            radial-gradient(ellipse at left center, rgba(255, 255, 255, .54), rgba(255, 250, 242, .16) 42%, rgba(255, 250, 242, 0) 72%),
            radial-gradient(ellipse at right center, rgba(255, 255, 255, .54), rgba(255, 250, 242, .16) 42%, rgba(255, 250, 242, 0) 72%);
        box-shadow: none !important;
    }

    .review-rail {
        padding-bottom: 24px !important;
    }
}

@media (max-width: 430px) {
    .horizontal-rail {
        border-radius: 22px;
    }
}

@media (prefers-reduced-motion: reduce) {
    .horizontal-rail,
    .review-rail {
        scroll-behavior: auto !important;
    }

    .review-rail .review-card {
        animation: none !important;
    }
}

/* Stage 1.6 — exact animated ZSky/Taha Bilal Çakmak logo system.
   Not: Küçük logo artık CSS yüzde/px border-radius karışımıyla değil, 1076x576 viewBox SVG ile çizilir.
   Böylece navbar/footer/admin küçük kullanımda şekiller orijinal oranını bozmaz.
   SEO/erişilebilirlik: logo dekoratif ikon olarak aria-hidden; marka adı gerçek metin olarak DOM'da kalır. */
.zsky-logo {
    --zsky-navy:#1D3557;
    --zsky-gray:#CFD3DB;
    --zsky-float-distance: -4px;
    display: inline-block;
    width: 100%;
    line-height: 0;
    vertical-align: middle;
    pointer-events: none;
}

.zsky-logo-stage {
    display: block;
    width: 100%;
    height: auto;
    overflow: visible;
}

.zsky-piece {
    transform-box: fill-box;
    transform-origin: center;
}

.zsky-float {
    animation-name: zskyFloat;
    animation-timing-function: cubic-bezier(.42, 0, .28, 1);
    animation-iteration-count: infinite;
    animation-fill-mode: both;
    transform: translateY(0);
    will-change: transform;
}

.zsky-piece--small-left {
    animation-duration: 1.48s;
    animation-delay: 0s;
}

.zsky-piece--big-left {
    animation-duration: 1.66s;
    animation-delay: .10s;
}

.zsky-piece--big-right {
    animation-duration: 1.66s;
    animation-delay: .24s;
}

.zsky-piece--small-right {
    animation-duration: 1.48s;
    animation-delay: .24s;
}

@keyframes zskyFloat {
    0%, 100% {
        transform: translateY(0);
    }

    50% {
        transform: translateY(var(--zsky-float-distance));
    }
}

.brand-mark {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 58px;
    height: auto;
    aspect-ratio: 1076 / 576;
    border-radius: 0;
    background: transparent;
    color: inherit;
    font-size: inherit;
    flex: 0 0 auto;
    overflow: visible;
}

.brand .zsky-logo--mark {
    width: 58px;
    min-width: 58px;
    --zsky-float-distance: -7.5px;
}

.footer .brand-mark {
    width: 68px;
    height: auto;
    aspect-ratio: 1076 / 576;
}

.footer .brand .zsky-logo--mark {
    width: 68px;
    min-width: 68px;
    --zsky-float-distance: -8px;
}

.site-loader {
    background:
        radial-gradient(circle at 50% 40%, rgba(255, 250, 242, .98) 0, rgba(246, 239, 227, .98) 40%, rgba(238, 224, 204, .98) 100%);
    transition: opacity .58s ease, visibility .58s ease;
}

.loader-card {
    width: min(620px, calc(100% - 40px));
    border: 1px solid rgba(31, 58, 52, .10);
    border-radius: 40px;
    background: rgba(255, 250, 242, .62);
    -webkit-backdrop-filter: blur(16px);
    backdrop-filter: blur(16px);
    box-shadow: 0 28px 90px rgba(54, 34, 15, .10);
    padding: clamp(28px, 5vw, 52px);
    text-align: center;
    display: grid;
    gap: 14px;
    justify-items: center;
}

.loader-card .zsky-logo--loader {
    width: min(500px, 78vw);
    --zsky-float-distance: -18px;
    filter: drop-shadow(0 20px 32px rgba(31, 58, 52, .10));
}

.loader-card strong {
    font-size: clamp(24px, 4vw, 38px);
    line-height: 1.05;
    letter-spacing: -.055em;
    color: var(--brand);
}

.loader-card small {
    color: var(--muted);
    max-width: 420px;
    line-height: 1.5;
}

.loader-mark {
    display: none;
}

@media (max-width: 620px) {
    .brand-mark,
    .brand .zsky-logo--mark {
        width: 48px;
        min-width: 48px;
        --zsky-float-distance: -5px;
    }

    .footer .brand-mark,
    .footer .brand .zsky-logo--mark {
        width: 56px;
        min-width: 56px;
        height: auto;
        aspect-ratio: 1076 / 576;
        --zsky-float-distance: -5.5px;
    }

    .loader-card {
        width: min(520px, calc(100% - 24px));
        border-radius: 32px;
        padding: 26px 20px;
    }

    .loader-card .zsky-logo--loader {
        width: min(430px, 84vw);
        --zsky-float-distance: -12px;
    }
}

@media (prefers-reduced-motion: reduce) {
    .zsky-float {
        animation: none !important;
    }
}

/* Sadece küçük navbar/footer logosunun yukarı-aşağı hareket ayarı */
.brand .zsky-logo--mark {
    --zsky-float-distance: -35px;
}

/* Küçük logoda hareket biraz daha fark edilir olsun */
.brand .zsky-logo--mark .zsky-piece--small-left,
.brand .zsky-logo--mark .zsky-piece--small-right {
    animation-duration: 1.25s;
}

.brand .zsky-logo--mark .zsky-piece--big-left,
.brand .zsky-logo--mark .zsky-piece--big-right {
    animation-duration: 1.42s;
}

/* Footer küçük logosu navbar’dan biraz daha geniş olduğu için hareket çok az daha fazla */
.footer .brand .zsky-logo--mark {
    --zsky-float-distance: -12px;
}

@media (max-width: 620px) {
    .brand .zsky-logo--mark {
        --zsky-float-distance: -8px;
    }

    .footer .brand .zsky-logo--mark {
        --zsky-float-distance: -8.5px;
    }
}

/* Brand palette + real logo usage.
   Logo image uses uploaded Taha Bilal Çakmak mark; visible text is replaced by image while semantic name stays in .sr-only. */
.sr-only {
    position: absolute !important;
    width: 1px !important;
    height: 1px !important;
    padding: 0 !important;
    margin: -1px !important;
    overflow: hidden !important;
    clip: rect(0, 0, 0, 0) !important;
    white-space: nowrap !important;
    border: 0 !important;
}

.brand--logo {
    display: inline-flex;
    align-items: center;
    justify-content: flex-start;
    gap: 0;
    min-width: 0;
}

.brand--logo .brand-logo-image {
    display: block;
    width: auto;
    height: clamp(42px, 5.4vw, 58px);
    max-width: min(380px, 54vw);
    object-fit: contain;
}

.nav {
    background: rgba(255,255,255,.92);
    border-bottom-color: rgba(207,211,219,.92);
}

.nav .brand--logo {
    border-radius: 18px;
    padding: 5px 8px;
    background: rgba(255,255,255,.72);
}

.footer .footer-brand-logo {
    width: fit-content;
    max-width: 100%;
    padding: 10px 14px;
    border-radius: 20px;
    background: rgba(255,255,255,.96);
    box-shadow: 0 18px 48px rgba(0,0,0,.16);
}

.footer .footer-brand-logo .brand-logo-image {
    height: clamp(48px, 5vw, 66px);
    max-width: min(420px, 84vw);
}

.site-loader .loader-card {
    background: rgba(255,255,255,.82);
    border-color: rgba(207,211,219,.82);
}

.site-loader .loader-card strong {
    color: var(--brand);
}

@media (max-width: 720px) {
    .brand--logo .brand-logo-image {
        height: 40px;
        max-width: min(300px, 62vw);
    }

    .nav .brand--logo {
        padding: 4px 6px;
    }
}

@media (max-width: 430px) {
    .brand--logo .brand-logo-image {
        height: 34px;
        max-width: 210px;
    }
}

/* Office photo gallery: replaces the homepage video display area without touching video backend. */
.office-gallery-section {
    position: relative;
    overflow: hidden;
    background:
        radial-gradient(circle at 16% 8%, rgba(161, 168, 184, .20), transparent 30%),
        radial-gradient(circle at 82% 20%, rgba(29, 53, 87, .10), transparent 34%),
        linear-gradient(180deg, rgba(255, 255, 255, .72), rgba(207, 211, 219, .22));
    border-block: 1px solid rgba(161, 168, 184, .28);
}

.office-gallery-section::before {
    content: "";
    position: absolute;
    inset: 0;
    pointer-events: none;
    background:
        linear-gradient(90deg, rgba(255,255,255,.44), transparent 24%, transparent 76%, rgba(255,255,255,.30)),
        radial-gradient(circle at 50% 100%, rgba(29, 53, 87, .08), transparent 46%);
}

.office-gallery-section .container {
    position: relative;
    z-index: 1;
}

.office-gallery-showcase {
    display: grid;
    grid-template-columns: minmax(0, 1.08fr) minmax(280px, .92fr);
    gap: clamp(18px, 3vw, 34px);
    align-items: stretch;
}

.office-gallery-feature,
.office-gallery-card {
    margin: 0;
    position: relative;
    overflow: hidden;
    background: rgba(255, 255, 255, .86);
    border: 1px solid rgba(161, 168, 184, .48);
    box-shadow: 0 24px 70px rgba(29, 53, 87, .12);
    transform: translateZ(0);
}

.office-gallery-feature {
    min-height: clamp(420px, 46vw, 620px);
    border-radius: 38px;
    isolation: isolate;
}

.office-gallery-feature::after {
    content: "";
    position: absolute;
    inset: 0;
    z-index: 1;
    pointer-events: none;
    background:
        linear-gradient(180deg, rgba(13, 24, 39, .02), rgba(13, 24, 39, .12) 42%, rgba(13, 24, 39, .76)),
        radial-gradient(circle at 80% 14%, rgba(255,255,255,.22), transparent 34%);
}

.office-gallery-feature img,
.office-gallery-card img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    transform: scale(1.002);
}

.office-gallery-feature img {
    position: absolute;
    inset: 0;
}

.office-gallery-feature figcaption {
    position: absolute;
    left: clamp(20px, 3vw, 34px);
    right: clamp(20px, 3vw, 34px);
    bottom: clamp(20px, 3vw, 34px);
    z-index: 2;
    display: grid;
    gap: 8px;
    color: #fff;
    max-width: 620px;
}

.office-gallery-feature figcaption span {
    width: fit-content;
    border: 1px solid rgba(255,255,255,.36);
    border-radius: 999px;
    background: rgba(255,255,255,.14);
    -webkit-backdrop-filter: blur(12px);
    backdrop-filter: blur(12px);
    color: rgba(255,255,255,.92);
    padding: 7px 12px;
    font-size: 13px;
    font-weight: 850;
}

.office-gallery-feature figcaption strong {
    font-size: clamp(30px, 4.8vw, 58px);
    line-height: .98;
    letter-spacing: -.06em;
}

.office-gallery-feature figcaption p {
    margin: 0;
    color: rgba(255,255,255,.84);
    max-width: 540px;
    font-size: clamp(15px, 1.6vw, 18px);
    line-height: 1.62;
}

.office-gallery-list {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 16px;
}

.office-gallery-card {
    min-height: 245px;
    border-radius: 28px;
    display: grid;
    grid-template-rows: minmax(142px, 1fr) auto;
    transition: transform .28s cubic-bezier(.2,.8,.2,1), box-shadow .28s ease, border-color .28s ease;
}

.office-gallery-card:hover,
.office-gallery-card:focus-within {
    transform: translateY(-4px);
    border-color: rgba(29, 53, 87, .38);
    box-shadow: 0 28px 78px rgba(29, 53, 87, .16);
}

.office-gallery-card img {
    min-height: 142px;
    aspect-ratio: 4 / 3;
}

.office-gallery-card figcaption {
    padding: 15px 16px 17px;
    display: grid;
    gap: 5px;
}

.office-gallery-card strong {
    color: var(--brand);
    font-size: 16px;
    line-height: 1.2;
    letter-spacing: -.02em;
}

.office-gallery-card p {
    margin: 0;
    color: var(--muted);
    font-size: 13.5px;
    line-height: 1.52;
}

/* Footer portrait: square framed image with desktop hover quote and mobile visible quote extension. */
.footer-grid {
    grid-template-columns: minmax(280px, 2fr) minmax(120px, .9fr) minmax(120px, .9fr) minmax(140px, .95fr) minmax(160px, 190px);
    align-items: start;
}

.footer-portrait-card {
    align-self: end;
    justify-self: end;
    width: min(190px, 100%);
}

.footer-portrait-card figure {
    margin: 0;
}

.footer-portrait-frame {
    position: relative;
    overflow: hidden;
    aspect-ratio: 1 / 1;
    border: 2px solid rgba(255,255,255,.92);
    border-radius: 26px;
    background: rgba(255,255,255,.08);
    box-shadow: 0 24px 64px rgba(0,0,0,.22);
    isolation: isolate;
}

.footer-portrait-frame img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: center 36%;
    filter: saturate(.95) contrast(1.02);
    transition: filter .34s ease, transform .34s cubic-bezier(.2,.8,.2,1);
}

.footer-portrait-overlay {
    position: absolute;
    inset: 0;
    z-index: 2;
    display: grid;
    place-items: center;
    padding: 18px;
    text-align: center;
    color: #fff;
    background: rgba(29, 53, 87, .36);
    opacity: 0;
    transition: opacity .28s ease;
}

.footer-portrait-overlay span,
.footer-portrait-card figcaption {
    font-family: ui-serif, Georgia, "Times New Roman", serif;
    font-size: 18px;
    line-height: 1.25;
    letter-spacing: -.02em;
    font-weight: 700;
}

.footer-portrait-frame:hover img,
.footer-portrait-frame:focus-within img {
    filter: blur(5px) saturate(.86) brightness(.78);
    transform: scale(1.035);
}

.footer-portrait-frame:hover .footer-portrait-overlay,
.footer-portrait-frame:focus-within .footer-portrait-overlay {
    opacity: 1;
}

.footer-portrait-card figcaption {
    display: none;
    color: #fff;
    margin-top: 0;
    padding: 14px 14px 16px;
    text-align: center;
    border: 2px solid rgba(255,255,255,.92);
    border-top: 0;
    border-radius: 0 0 22px 22px;
    background: rgba(255,255,255,.08);
}

@media (max-width: 1180px) {
    .office-gallery-showcase {
        grid-template-columns: 1fr;
    }

    .office-gallery-list {
        display: flex;
        gap: 16px;
        overflow-x: auto;
        overflow-y: hidden;
        scroll-snap-type: x proximity;
        padding: 4px 2px 20px;
    }

    .office-gallery-card {
        flex: 0 0 min(330px, 80vw);
        scroll-snap-align: start;
    }

    .footer-grid {
        grid-template-columns: minmax(260px, 1.4fr) repeat(3, minmax(120px, 1fr));
    }

    .footer-portrait-card {
        grid-column: 1 / -1;
        justify-self: end;
        margin-top: 8px;
    }
}

@media (max-width: 960px) {
    .office-gallery-feature {
        min-height: 440px;
        border-radius: 32px;
    }

    .footer-grid {
        grid-template-columns: 1fr 1fr;
    }

    .footer-portrait-card {
        grid-column: 2;
        justify-self: end;
    }
}

@media (max-width: 720px) {
    .office-gallery-section {
        background: linear-gradient(180deg, rgba(255,255,255,.78), rgba(207,211,219,.16));
    }

    .office-gallery-feature {
        min-height: 380px;
        border-radius: 28px;
    }

    .office-gallery-card {
        flex-basis: min(310px, 84vw);
        border-radius: 24px;
    }

    .footer-portrait-frame {
        border-radius: 24px 24px 0 0;
    }

    .footer-portrait-frame:hover img,
    .footer-portrait-frame:focus-within img {
        filter: saturate(.95) contrast(1.02);
        transform: none;
    }

    .footer-portrait-overlay {
        display: none;
    }

    .footer-portrait-card figcaption {
        display: block;
    }
}

@media (max-width: 620px) {
    .office-gallery-feature {
        min-height: 330px;
    }

    .office-gallery-feature figcaption {
        left: 18px;
        right: 18px;
        bottom: 18px;
    }

    .office-gallery-feature figcaption strong {
        font-size: 30px;
    }

    .office-gallery-card {
        flex-basis: 84vw;
    }

    .footer-grid {
        grid-template-columns: 1fr;
    }

    .footer-portrait-card {
        grid-column: auto;
        justify-self: start;
        width: min(220px, 72vw);
    }
}

@media (prefers-reduced-motion: reduce) {
    .office-gallery-card,
    .footer-portrait-frame img,
    .footer-portrait-overlay {
        transition: none !important;
    }
}


/* Office gallery interaction fix + solid mobile menu patch */
.office-gallery-showcase[data-office-gallery] {
    align-items: stretch;
}

.office-gallery-feature img {
    transition: opacity .28s ease, transform .42s cubic-bezier(.2,.8,.2,1), filter .28s ease;
}

.office-gallery-feature.is-changing img {
    opacity: .38;
    transform: scale(1.015);
    filter: saturate(.9) blur(2px);
}

.office-gallery-list {
    scroll-behavior: smooth;
}

.office-gallery-card {
    -webkit-appearance: none;
    appearance: none;
    border: 1px solid rgba(161, 168, 184, .55);
    text-align: left;
    cursor: pointer;
    color: inherit;
    font: inherit;
    padding: 0;
}

.office-gallery-card:focus-visible {
    outline: 3px solid rgba(29, 53, 87, .34);
    outline-offset: 4px;
}

.office-gallery-card.is-active {
    border-color: rgba(29, 53, 87, .62);
    box-shadow: 0 24px 70px rgba(29, 53, 87, .16);
    transform: translateY(-4px);
}

.office-gallery-card.is-active::before {
    content: "";
    position: absolute;
    inset: 0;
    border-radius: inherit;
    pointer-events: none;
    box-shadow: inset 0 0 0 2px rgba(255, 255, 255, .76), inset 0 0 0 3px rgba(29, 53, 87, .24);
    z-index: 2;
}

.office-gallery-card-copy {
    display: grid;
    gap: 7px;
    padding: 18px;
}

.office-gallery-card-copy small {
    display: block;
    color: var(--muted);
    font-size: 14px;
    line-height: 1.55;
}

.office-gallery-card figcaption {
    display: none;
}

@media (max-width: 960px) {
    .nav {
        z-index: 90;
    }

    .nav-inner {
        position: relative;
    }

    .menu {
        position: fixed !important;
        top: calc(var(--nav-height, 74px) + 10px) !important;
        left: 14px !important;
        right: 14px !important;
        z-index: 120;
        display: none;
        flex-direction: column;
        align-items: stretch;
        gap: 8px;
        padding: 16px;
        border: 1px solid rgba(161, 168, 184, .48);
        border-radius: 26px;
        background: #FFFFFF !important;
        color: var(--ink);
        box-shadow: 0 28px 90px rgba(29, 53, 87, .22), 0 8px 24px rgba(29, 53, 87, .10);
        opacity: 1 !important;
        -webkit-backdrop-filter: none !important;
        backdrop-filter: none !important;
    }

    .menu.is-open {
        display: flex;
    }

    .menu a {
        width: 100%;
        padding: 13px 14px;
        border-radius: 16px;
        background: rgba(207, 211, 219, .26);
        font-weight: 800;
    }

    .menu a:not(.btn):hover,
    .menu a:not(.btn):focus-visible {
        background: rgba(29, 53, 87, .08);
        color: var(--brand);
    }

    .menu .btn,
    .menu a.btn {
        margin-top: 4px;
        justify-content: center;
        background: var(--brand);
        color: #FFFFFF;
    }

    body.mobile-menu-open::before {
        content: "";
        position: fixed;
        inset: 0;
        z-index: 80;
        background: rgba(29, 53, 87, .28);
        pointer-events: none;
    }
}

@media (max-width: 620px) {
    .menu {
        top: calc(var(--nav-height, 64px) + 8px) !important;
        left: 12px !important;
        right: 12px !important;
        border-radius: 22px;
        padding: 14px;
    }

    .office-gallery-card-copy {
        padding: 15px;
    }
}

@media (prefers-reduced-motion: reduce) {
    .office-gallery-feature img,
    .office-gallery-card,
    .office-gallery-list {
        transition: none !important;
        scroll-behavior: auto !important;
    }
}





/* Loader dış zeminini tamamen opak yapar: arkadaki site görünmez */
.site-loader {
    position: fixed !important;
    inset: 0 !important;
    z-index: 9999 !important;
    opacity: 1 !important;
    visibility: visible;
    background:
        radial-gradient(
            circle at 50% 42%,
            #DCE2EA 0%,
            #CFD3DB 30%,
            #A1A8B8 62%,
            #757F97 100%
        ) !important;
}

/* Loader kapanırken yine normal şekilde kaybolsun */
.site-loader.is-hidden {
    opacity: 0 !important;
    visibility: hidden !important;
    pointer-events: none !important;
}