*{
margin:0;
padding:0;
box-sizing:border-box;
}

:root{
--bg:#f5ede8;
--bg-soft:#efe2da;
--surface:#fffaf6;
--surface-alt:#f7efe9;
--surface-deep:#2a1719;
--surface-deeper:#170c0d;
--text:#241618;
--text-soft:#5d4a4c;
--text-muted:#8a6f73;
--brand:#ad2831;
--brand-strong:#8f2028;
--brand-bright:#cf4c52;
--brand-soft:#f6dcde;
--brand-line:rgba(173,40,49,0.14);
--accent:#e0ab73;
--white-soft:rgba(255,255,255,0.76);
--shadow-lg:0 30px 60px rgba(65,27,30,0.14);
--shadow-md:0 18px 36px rgba(65,27,30,0.1);
--radius-xl:32px;
--radius-lg:24px;
--radius-md:18px;
--container:1180px;
}

html{
scroll-behavior:smooth;
}

body{
font-family:"DM Sans",sans-serif;
background:
radial-gradient(circle at top left,rgba(173,40,49,0.1) 0%,rgba(173,40,49,0) 24%),
radial-gradient(circle at top right,rgba(224,171,115,0.18) 0%,rgba(224,171,115,0) 20%),
linear-gradient(180deg,#f8f1ec 0%,#fffaf6 40%,#f3e7df 100%);
color:var(--text);
line-height:1.6;
}

h1,h2,h3,.logo-name,.footer-logo{
font-family:"Space Grotesk",sans-serif;
}

img{
max-width:100%;
}

a{
color:inherit;
}

.cursor-dot,
.cursor-ring{
position:fixed;
top:0;
left:0;
pointer-events:none;
opacity:0;
transform:translate(-50%,-50%);
transition:opacity 0.2s ease,transform 0.2s ease;
z-index:9999;
}

.cursor-dot{
width:10px;
height:10px;
border-radius:50%;
background:var(--brand-bright);
box-shadow:0 0 18px rgba(207,76,82,0.45);
}

.cursor-ring{
width:42px;
height:42px;
border-radius:50%;
border:1.5px solid rgba(173,40,49,0.36);
background:rgba(173,40,49,0.08);
backdrop-filter:blur(4px);
}

.cursor-dot.active,
.cursor-ring.active{
opacity:1;
}

.cursor-ring.cursor-hover{
transform:translate(-50%,-50%) scale(1.2);
border-color:rgba(255,255,255,0.82);
background:rgba(255,255,255,0.12);
}

section{
scroll-margin-top:100px;
}

.container{
width:min(92%,var(--container));
margin:auto;
}

.header{
position:fixed;
top:0;
width:100%;
z-index:20;
background:rgba(23,12,13,0.84);
backdrop-filter:blur(18px);
border-bottom:1px solid rgba(255,255,255,0.08);
}

.nav{
display:flex;
align-items:center;
justify-content:space-between;
padding:16px 0;
gap:20px;
}

.logo{
display:flex;
align-items:center;
gap:12px;
}

.logo img,
.footer-brand-logo{
display:block;
height:56px;
width:auto;
border-radius:16px;
border:1px solid rgba(255,255,255,0.12);
box-shadow:0 14px 28px rgba(0,0,0,0.22);
filter:sepia(0.28) saturate(0.92) hue-rotate(-18deg) contrast(1.04);
}

.logo-text{
display:flex;
flex-direction:column;
gap:2px;
line-height:1;
color:#ffffff;
}

.logo-name{
font-size:1.2rem;
font-weight:700;
letter-spacing:0.08em;
}

.logo-sub{
font-size:0.72rem;
font-weight:700;
letter-spacing:0.28em;
text-transform:uppercase;
color:#f3c9b8;
}

.menu{
display:flex;
align-items:center;
gap:24px;
}

.menu a{
position:relative;
text-decoration:none;
font-size:0.92rem;
font-weight:600;
letter-spacing:0.06em;
text-transform:uppercase;
color:rgba(255,255,255,0.8);
transition:color 0.22s ease,opacity 0.22s ease;
}

.menu a:hover,
.menu a.active{
color:#ffffff;
}

.menu a.active::after{
content:"";
position:absolute;
left:0;
bottom:-9px;
width:100%;
height:2px;
border-radius:999px;
background:linear-gradient(90deg,var(--accent) 0%,#f7dfd0 100%);
box-shadow:0 0 18px rgba(224,171,115,0.35);
}

.menu-toggle{
display:none;
font-size:1.25rem;
color:#ffffff;
cursor:pointer;
}

.hero{
position:relative;
min-height:100vh;
display:flex;
align-items:center;
padding:140px 0 90px;
overflow:hidden;
background:
radial-gradient(circle at 18% 22%,rgba(224,171,115,0.18) 0%,rgba(224,171,115,0) 24%),
radial-gradient(circle at 82% 16%,rgba(207,76,82,0.22) 0%,rgba(207,76,82,0) 22%),
linear-gradient(135deg,#170c0d 0%,#3b1518 46%,#ad2831 100%);
color:#ffffff;
}

.hero::before{
content:"";
position:absolute;
inset:auto auto 8% -5%;
width:320px;
height:320px;
border-radius:50%;
background:radial-gradient(circle,rgba(255,243,234,0.2) 0%,rgba(255,243,234,0) 70%);
filter:blur(12px);
}

.hero::after{
content:"";
position:absolute;
top:12%;
right:-6%;
width:360px;
height:360px;
border-radius:50%;
background:radial-gradient(circle,rgba(224,171,115,0.24) 0%,rgba(224,171,115,0) 72%);
filter:blur(24px);
}

.hero-layout{
position:relative;
z-index:1;
display:grid;
grid-template-columns:minmax(0,1fr) minmax(320px,0.92fr);
gap:56px;
align-items:center;
}

.hero-content{
display:flex;
flex-direction:column;
align-items:flex-start;
}

.eyebrow,
.section-tag,
.portfolio-label{
display:inline-flex;
align-items:center;
gap:8px;
padding:8px 14px;
border-radius:999px;
font-size:0.78rem;
font-weight:700;
letter-spacing:0.16em;
text-transform:uppercase;
}

.eyebrow{
margin-bottom:20px;
background:rgba(255,255,255,0.08);
border:1px solid rgba(255,255,255,0.14);
color:#f8dac4;
}

.hero h1{
font-size:clamp(2.7rem,6vw,5.1rem);
line-height:0.96;
letter-spacing:-0.05em;
max-width:8.5ch;
margin-bottom:18px;
}

.hero p{
max-width:610px;
font-size:1.12rem;
line-height:1.85;
color:rgba(255,255,255,0.8);
}

.hero-btn{
align-self:flex-start;
}

.hero-visual{
position:relative;
padding:22px;
border-radius:34px;
background:linear-gradient(180deg,rgba(255,255,255,0.11) 0%,rgba(255,255,255,0.04) 100%);
border:1px solid rgba(255,255,255,0.12);
box-shadow:0 28px 70px rgba(10,3,4,0.36);
backdrop-filter:blur(8px);
}

.hero-visual::before{
content:"";
position:absolute;
inset:auto 36px -24px 36px;
height:32px;
background:rgba(0,0,0,0.34);
filter:blur(28px);
}

.hero-visual img{
position:relative;
z-index:1;
display:block;
width:100%;
max-height:540px;
object-fit:contain;
}

.btn{
display:inline-flex;
align-items:center;
justify-content:center;
gap:10px;
padding:15px 30px;
margin-top:30px;
border-radius:999px;
text-decoration:none;
font-weight:700;
letter-spacing:0.03em;
color:#ffffff;
background:linear-gradient(135deg,var(--brand) 0%,var(--brand-bright) 100%);
box-shadow:0 18px 36px rgba(173,40,49,0.28);
transition:transform 0.22s ease,box-shadow 0.22s ease,filter 0.22s ease;
}

.btn:hover{
transform:translateY(-3px);
box-shadow:0 24px 42px rgba(173,40,49,0.34);
filter:brightness(1.03);
}

.btn span{
transition:transform 0.22s ease;
}

.btn:hover span{
transform:translateX(3px);
}

.section{
padding:104px 0;
text-align:center;
}

.light{
background:transparent;
}

.about{
background:
radial-gradient(circle at top left,rgba(173,40,49,0.12) 0%,rgba(173,40,49,0) 26%),
linear-gradient(180deg,#f7efea 0%,#fffaf6 100%);
}

.about-grid,
.stats-layout{
display:grid;
grid-template-columns:1.05fr 0.95fr;
gap:40px;
align-items:center;
text-align:left;
}

.section-tag{
margin-bottom:18px;
background:var(--brand-soft);
border:1px solid rgba(173,40,49,0.12);
color:var(--brand);
}

.about-copy h2,
.portfolio-heading h2,
.stats-intro h2,
.contact-heading h2,
.policy-card h1{
font-size:clamp(2.15rem,4vw,3.5rem);
line-height:1.08;
letter-spacing:-0.04em;
color:var(--text);
}

.about-copy h2{
margin-bottom:18px;
}

.about-copy p,
.portfolio-heading p,
.contact-heading p,
.policy-card p,
.policy-card li{
font-size:1.02rem;
line-height:1.82;
color:var(--text-soft);
}

.about-copy p + p{
margin-top:12px;
}

.about-panel{
padding:36px;
border-radius:var(--radius-xl);
background:linear-gradient(180deg,#31181a 0%,#190d0e 100%);
color:#ffffff;
box-shadow:var(--shadow-lg);
border:1px solid rgba(255,255,255,0.08);
}

.about-highlight{
padding-bottom:24px;
margin-bottom:24px;
border-bottom:1px solid rgba(255,255,255,0.1);
}

.about-highlight i{
font-size:1.65rem;
margin-bottom:14px;
color:#f0c59e;
}

.about-highlight h3{
font-size:1.4rem;
margin-bottom:10px;
}

.about-highlight p,
.about-points span{
color:var(--white-soft);
}

.about-points{
display:grid;
gap:18px;
}

.about-points div{
display:flex;
flex-direction:column;
gap:4px;
}

.about-points strong{
font-size:1.16rem;
color:#ffe6d7;
}

.grid{
display:grid;
grid-template-columns:repeat(auto-fit,minmax(240px,1fr));
gap:24px;
margin-top:42px;
}

.card{
background:var(--surface);
}

#services h2{
font-size:clamp(2.2rem,4vw,3.4rem);
letter-spacing:-0.04em;
}

.services-grid{
perspective:1200px;
}

.service-card,
.portfolio-card,
.contact-tile,
.policy-card{
background:linear-gradient(180deg,#fffaf6 0%,#f8f0ea 100%);
border:1px solid var(--brand-line);
box-shadow:var(--shadow-md);
}

.service-card{
position:relative;
overflow:hidden;
padding:28px;
border-radius:28px;
text-align:left;
transition:transform 0.3s ease,box-shadow 0.3s ease,border-color 0.3s ease;
transform-style:preserve-3d;
}

.service-card::before{
content:"";
position:absolute;
top:-40px;
right:-30px;
width:160px;
height:160px;
border-radius:50%;
background:radial-gradient(circle,rgba(224,171,115,0.22) 0%,rgba(224,171,115,0) 70%);
opacity:0;
transition:opacity 0.3s ease,transform 0.3s ease;
}

.service-card::after{
content:"";
position:absolute;
left:0;
bottom:0;
width:100%;
height:4px;
background:linear-gradient(90deg,var(--brand) 0%,var(--accent) 100%);
transform:scaleX(0.26);
transform-origin:left;
transition:transform 0.3s ease;
}

.service-card:hover{
transform:translateY(-10px);
box-shadow:0 26px 44px rgba(65,27,30,0.16);
border-color:rgba(173,40,49,0.24);
}

.service-card:hover::before{
opacity:1;
transform:translate(-10px,8px);
}

.service-card:hover::after{
transform:scaleX(1);
}

.service-number,
.portfolio-card-index{
font-size:0.82rem;
font-weight:700;
letter-spacing:0.16em;
color:var(--text-muted);
}

.service-number{
display:inline-block;
margin-bottom:22px;
}

.service-top{
position:relative;
z-index:1;
display:flex;
align-items:center;
justify-content:space-between;
margin-bottom:22px;
}

.icon{
font-size:2rem;
color:var(--brand);
}

.service-arrow{
display:inline-flex;
align-items:center;
justify-content:center;
width:44px;
height:44px;
border-radius:50%;
background:var(--brand-soft);
color:var(--brand);
font-weight:700;
transition:transform 0.3s ease,background 0.3s ease,color 0.3s ease;
}

.service-card:hover .service-arrow{
transform:translateX(4px) rotate(-10deg);
background:var(--brand);
color:#ffffff;
}

.service-card h3,
.portfolio-feature-copy h3,
.portfolio-card h3{
position:relative;
z-index:1;
margin-bottom:12px;
font-size:1.5rem;
line-height:1.16;
letter-spacing:-0.03em;
}

.service-card p,
.portfolio-card p{
position:relative;
z-index:1;
color:var(--text-soft);
line-height:1.78;
}

.portfolio-heading{
max-width:780px;
margin:0 auto 44px;
}

.portfolio-heading h2,
.stats-intro h2,
.contact-heading h2{
margin-top:10px;
}

.portfolio-heading p{
margin-top:16px;
}

.portfolio-feature{
display:grid;
grid-template-columns:0.96fr 1.04fr;
gap:30px;
align-items:stretch;
margin-bottom:28px;
padding:34px;
border-radius:36px;
background:
radial-gradient(circle at top left,rgba(224,171,115,0.18) 0%,rgba(224,171,115,0) 30%),
linear-gradient(135deg,#251314 0%,#5a1d21 55%,#ad2831 100%);
box-shadow:0 30px 58px rgba(42,18,20,0.22);
overflow:hidden;
}

.portfolio-feature-copy{
text-align:left;
color:#ffffff;
}

.portfolio-label{
margin-bottom:14px;
background:rgba(255,255,255,0.12);
border:1px solid rgba(255,255,255,0.12);
color:#ffe4d4;
}

.portfolio-feature-copy h3{
font-size:clamp(1.8rem,3vw,2.5rem);
color:#ffffff;
}

.portfolio-feature-copy p{
margin-bottom:22px;
max-width:520px;
line-height:1.82;
color:rgba(255,255,255,0.8);
}

.portfolio-meta{
display:flex;
flex-wrap:wrap;
gap:10px;
}

.portfolio-feature .portfolio-meta span,
.portfolio-card .portfolio-meta span{
padding:9px 14px;
border-radius:999px;
font-size:0.9rem;
font-weight:600;
}

.portfolio-feature .portfolio-meta span{
background:rgba(255,255,255,0.08);
border:1px solid rgba(255,255,255,0.12);
color:#fff0e8;
}

.portfolio-feature-stats{
display:grid;
grid-template-columns:repeat(2,minmax(0,1fr));
gap:14px;
margin-top:24px;
}

.portfolio-feature-stats div{
padding:16px 18px;
border-radius:22px;
background:rgba(255,255,255,0.08);
border:1px solid rgba(255,255,255,0.1);
backdrop-filter:blur(8px);
}

.portfolio-feature-stats strong{
display:block;
margin-bottom:6px;
color:#ffffff;
}

.portfolio-feature-stats span{
color:rgba(255,255,255,0.74);
font-size:0.94rem;
line-height:1.65;
}

.portfolio-feature-visual{
position:relative;
display:flex;
align-items:center;
justify-content:center;
padding:20px;
border-radius:28px;
background:linear-gradient(180deg,rgba(255,255,255,0.12) 0%,rgba(255,255,255,0.04) 100%);
border:1px solid rgba(255,255,255,0.12);
}

.portfolio-feature-visual::before{
content:"";
position:absolute;
inset:auto 30px -20px 30px;
height:28px;
background:rgba(4,2,3,0.45);
filter:blur(24px);
}

.portfolio-feature-visual img{
position:relative;
z-index:1;
border-radius:20px;
box-shadow:0 22px 44px rgba(0,0,0,0.22);
}

.portfolio-grid{
display:grid;
grid-template-columns:repeat(3,minmax(0,1fr));
gap:22px;
}

.portfolio-card{
display:flex;
flex-direction:column;
height:100%;
padding:24px;
border-radius:28px;
text-align:left;
}

.portfolio-card-top{
display:flex;
align-items:center;
justify-content:space-between;
gap:12px;
margin-bottom:10px;
}

.portfolio-card h3{
color:var(--text);
}

.portfolio-card p{
margin-bottom:22px;
}

.portfolio-card-media{
margin-top:auto;
margin-bottom:20px;
padding:16px;
border-radius:24px;
background:linear-gradient(180deg,#f5e8e3 0%,#fffaf6 100%);
border:1px solid rgba(173,40,49,0.08);
}

.portfolio-card-media img{
border-radius:16px;
box-shadow:0 16px 30px rgba(65,27,30,0.1);
}

.portfolio-card .portfolio-meta span{
background:var(--brand-soft);
color:var(--brand);
}

.stats{
position:relative;
overflow:hidden;
background:
radial-gradient(circle at top left,rgba(224,171,115,0.16) 0%,rgba(224,171,115,0) 30%),
radial-gradient(circle at bottom right,rgba(207,76,82,0.18) 0%,rgba(207,76,82,0) 28%),
linear-gradient(180deg,#1d0d0e 0%,#44171a 100%);
color:#ffffff;
}

.stats::before,
.stats::after{
content:"";
position:absolute;
border-radius:50%;
filter:blur(10px);
opacity:0.65;
pointer-events:none;
}

.stats::before{
top:50px;
left:-80px;
width:260px;
height:260px;
background:radial-gradient(circle,rgba(224,171,115,0.24) 0%,rgba(224,171,115,0) 70%);
animation:statsGlow 8s ease-in-out infinite;
}

.stats::after{
right:-90px;
bottom:20px;
width:320px;
height:320px;
background:radial-gradient(circle,rgba(207,76,82,0.24) 0%,rgba(207,76,82,0) 70%);
animation:statsGlow 10s ease-in-out infinite reverse;
}

.stats-intro{
position:relative;
z-index:1;
text-align:left;
}

.stats-intro h2{
color:#ffffff;
}

.stats-intro .section-tag{
background:rgba(255,255,255,0.08);
border:1px solid rgba(255,255,255,0.12);
color:#ffe4d4;
}

.stats-intro p{
max-width:520px;
margin-top:16px;
color:rgba(255,255,255,0.76);
line-height:1.85;
}

.stats-highlight{
margin-top:26px;
padding:18px 20px;
border-radius:24px;
background:rgba(255,255,255,0.07);
border:1px solid rgba(255,255,255,0.1);
box-shadow:0 18px 35px rgba(0,0,0,0.18);
backdrop-filter:blur(10px);
animation:statsPanelFloat 5.5s ease-in-out infinite;
}

.stats-highlight strong{
display:block;
margin-bottom:8px;
}

.stats-highlight span{
color:rgba(255,255,255,0.72);
}

.stats-grid{
position:relative;
z-index:1;
display:grid;
grid-template-columns:repeat(2,minmax(0,1fr));
gap:20px;
}

.stat{
position:relative;
overflow:hidden;
padding:28px;
border-radius:28px;
text-align:left;
background:linear-gradient(180deg,rgba(255,255,255,0.1) 0%,rgba(255,255,255,0.04) 100%);
border:1px solid rgba(255,255,255,0.1);
box-shadow:0 22px 40px rgba(0,0,0,0.18);
backdrop-filter:blur(10px);
transition:transform 0.3s ease,box-shadow 0.3s ease,border-color 0.3s ease;
animation:statsCardFloat 6s ease-in-out infinite;
}

.stat::before{
content:"";
position:absolute;
top:-36px;
right:-22px;
width:130px;
height:130px;
border-radius:50%;
background:radial-gradient(circle,rgba(224,171,115,0.32) 0%,rgba(224,171,115,0) 72%);
}

.stat::after{
content:"";
position:absolute;
left:-20%;
bottom:0;
width:60%;
height:3px;
background:linear-gradient(90deg,rgba(224,171,115,0) 0%,#f0c59e 50%,rgba(224,171,115,0) 100%);
animation:statsLineSweep 4.8s linear infinite;
}

.stat-large{
grid-row:span 2;
display:flex;
flex-direction:column;
justify-content:flex-end;
min-height:280px;
background:linear-gradient(180deg,rgba(224,171,115,0.16) 0%,rgba(255,255,255,0.04) 100%);
}

.stat-wide{
grid-column:span 2;
}

.stat:nth-child(2){
animation-delay:0.4s;
}

.stat:nth-child(3){
animation-delay:0.9s;
}

.stat:nth-child(4){
animation-delay:1.2s;
}

.stat h2{
position:relative;
z-index:1;
font-size:clamp(2.5rem,5vw,4.8rem);
line-height:1;
letter-spacing:-0.05em;
margin-bottom:14px;
}

.stat p{
position:relative;
z-index:1;
max-width:190px;
font-size:1rem;
line-height:1.6;
color:rgba(255,255,255,0.8);
}

.stat:hover{
transform:translateY(-8px) scale(1.01);
box-shadow:0 30px 52px rgba(0,0,0,0.24);
border-color:rgba(255,255,255,0.16);
}

.contact{
background:
radial-gradient(circle at top center,rgba(173,40,49,0.1) 0%,rgba(173,40,49,0) 28%),
linear-gradient(180deg,#f7efea 0%,#fffaf6 100%);
}

.contact-heading{
max-width:760px;
margin:0 auto;
}

.contact-heading p{
max-width:640px;
margin:14px auto 0;
}

.contact-hub{
margin-top:44px;
padding:36px;
border-radius:38px;
background:linear-gradient(180deg,#fffaf6 0%,#f7eee8 100%);
border:1px solid rgba(173,40,49,0.08);
box-shadow:var(--shadow-lg);
}

.contact-cards-grid{
display:grid;
grid-template-columns:repeat(3,1fr);
gap:20px;
margin-bottom:24px;
align-items:stretch;
}

.contact-tile{
display:flex;
flex-direction:column;
justify-content:flex-start;
min-height:100%;
padding:24px;
border-radius:26px;
text-align:left;
transition:transform 0.25s ease,box-shadow 0.25s ease;
}

.contact-tile:hover{
transform:translateY(-6px);
box-shadow:0 24px 38px rgba(65,27,30,0.14);
}

.contact-tile i{
display:inline-flex;
align-items:center;
justify-content:center;
width:54px;
height:54px;
margin-bottom:16px;
border-radius:18px;
background:linear-gradient(135deg,var(--brand) 0%,var(--brand-bright) 100%);
color:#ffffff;
font-size:1.15rem;
box-shadow:0 16px 28px rgba(173,40,49,0.2);
}

.contact-tile-label{
display:block;
margin-bottom:8px;
font-size:0.8rem;
font-weight:700;
letter-spacing:0.16em;
text-transform:uppercase;
color:var(--brand);
}

.contact-tile a,
.contact-tile p{
margin:0;
font-size:1.05rem;
line-height:1.68;
text-decoration:none;
color:var(--text);
}

.contact-map-strip{
overflow:hidden;
border-radius:30px;
border:1px solid rgba(173,40,49,0.08);
box-shadow:0 20px 40px rgba(65,27,30,0.08);
}

.footer-top{
padding:82px 0 36px;
background:linear-gradient(180deg,#241213 0%,#120809 100%);
color:rgba(255,255,255,0.84);
}

.footer-grid{
display:grid;
grid-template-columns:1.2fr 0.9fr 1fr 1.1fr;
gap:40px;
align-items:start;
}

.footer-brand{
max-width:290px;
}

.footer-brand-head{
display:flex;
align-items:center;
gap:14px;
margin-bottom:18px;
}

.footer-logo{
font-size:2rem;
font-weight:700;
line-height:0.95;
letter-spacing:0.04em;
color:#ffffff;
}

.footer-brand p,
.footer-column p,
.footer-column a{
font-size:1rem;
line-height:1.8;
color:rgba(255,255,255,0.72);
text-decoration:none;
}

.footer-column{
display:flex;
flex-direction:column;
gap:8px;
}

.footer-column h3{
margin-bottom:14px;
font-size:1.02rem;
font-weight:700;
letter-spacing:0.1em;
text-transform:uppercase;
color:#ffd8c7;
}

.footer-column a:hover{
color:#ffffff;
}

footer{
padding:24px 0 34px;
background:#120809;
border-top:1px solid rgba(255,255,255,0.08);
color:rgba(255,255,255,0.68);
text-align:center;
}

.footer-content{
display:flex;
align-items:center;
justify-content:center;
gap:18px;
text-align:center;
}

.policy-page{
background:
radial-gradient(circle at top left,rgba(173,40,49,0.1) 0%,rgba(173,40,49,0) 24%),
linear-gradient(180deg,#f8f1ec 0%,#fffaf6 100%);
}

.policy-page .logo span{
color:#ffffff;
font-size:1rem;
font-weight:700;
letter-spacing:0.04em;
}

.policy-main{
padding:142px 0 84px;
}

.policy-card{
max-width:900px;
margin:0 auto;
padding:44px;
border-radius:32px;
}

.policy-card h1{
margin-bottom:14px;
}

.policy-updated{
margin-bottom:28px;
font-size:0.95rem;
color:var(--text-muted);
}

.policy-card h2{
margin:28px 0 12px;
font-size:1.35rem;
letter-spacing:-0.02em;
color:var(--text);
}

.policy-card ul{
padding-left:20px;
}

.policy-actions{
margin-top:30px;
}

@keyframes statsGlow{
0%,100%{transform:translate3d(0,0,0) scale(1)}
50%{transform:translate3d(18px,-12px,0) scale(1.08)}
}

@keyframes statsCardFloat{
0%,100%{transform:translateY(0)}
50%{transform:translateY(-8px)}
}

@keyframes statsPanelFloat{
0%,100%{transform:translateY(0)}
50%{transform:translateY(-6px)}
}

@keyframes statsLineSweep{
0%{transform:translateX(0)}
100%{transform:translateX(220%)}
}

@media(max-width:992px){
.hero-layout,
.about-grid,
.stats-layout,
.portfolio-feature{
grid-template-columns:1fr;
}

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

.contact-cards-grid{
grid-template-columns:1fr;
}

.footer-grid{
grid-template-columns:repeat(2,minmax(0,1fr));
}
}

@media(max-width:768px){
.menu{
display:none;
position:absolute;
top:78px;
right:4%;
width:min(280px,88vw);
padding:20px;
border-radius:22px;
flex-direction:column;
align-items:flex-start;
gap:14px;
background:rgba(23,12,13,0.96);
border:1px solid rgba(255,255,255,0.08);
box-shadow:0 24px 40px rgba(0,0,0,0.22);
}

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

.menu-toggle{
display:block;
}

.hero{
padding:118px 0 72px;
min-height:auto;
}

.hero-content{
align-items:center;
text-align:center;
}

.hero h1{
max-width:none;
font-size:clamp(2.2rem,11vw,3.5rem);
}

.hero p{
font-size:1rem;
}

.hero-btn{
align-self:center;
}

.hero-visual{
padding:16px;
}

.hero-visual img{
max-height:360px;
}

.section{
padding:84px 0;
}

.portfolio-feature,
.contact-hub,
.policy-card,
.about-panel{
padding:24px;
}

.portfolio-feature-stats,
.stats-grid,
.footer-grid{
grid-template-columns:1fr;
}

.stat-large,
.stat-wide{
grid-column:auto;
grid-row:auto;
min-height:auto;
}

.stat p{
max-width:none;
}

.footer-content{
flex-direction:column;
}
}
