
/* ===== VARIABLES & RESET ===== */
:root {
    --bg: #f5f2ed;
    --bg2: #ede9e2;
    --surface: #ffffff;
    --text: #1a1714;
    --text-soft: #6b6460;
    --accent: #b8860b;
    --accent2: #8b4513;
    --border: rgba(26,23,20,0.12);
    --nav-h: 72px;
    --font-display: 'Cormorant Garamond', Georgia, serif;
    --font-body: 'Josefin Sans', sans-serif;
    --radius: 2px;
    --shadow: 0 8px 40px rgba(0,0,0,0.08);
    --shadow-lg: 0 20px 80px rgba(0,0,0,0.12);
    --transition: 0.4s cubic-bezier(0.25,0.46,0.45,0.94);
}
[data-theme="dark"] {
    --bg: #0f0d0b;
    --bg2: #181410;
    --surface: #1e1a16;
    --text: #f0ebe4;
    --text-soft: #9e9790;
    --accent: #d4a017;
    --accent2: #c06030;
    --border: rgba(240,235,228,0.10);
    --shadow: 0 8px 40px rgba(0,0,0,0.4);
    --shadow-lg: 0 20px 80px rgba(0,0,0,0.5);
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;}
html{scroll-behavior:smooth;font-size:16px;}
body{
    font-family:var(--font-body);
    background:var(--bg);
    color:var(--text);
    line-height:1.7;
    overflow-x:hidden;
    transition:background var(--transition),color var(--transition);
}
img{max-width:100%;display:block;}
a{color:inherit;text-decoration:none;}
ul{list-style:none;}
button{cursor:pointer;border:none;background:none;font-family:inherit;}

/* ===== SCROLLBAR ===== */
::-webkit-scrollbar{width:4px;}
::-webkit-scrollbar-track{background:var(--bg);}
::-webkit-scrollbar-thumb{background:var(--accent);border-radius:2px;}

/* ===== SKIP LINK ===== */
.skip-link{
    position:fixed;top:-100px;left:20px;z-index:9999;
    background:var(--accent);color:#fff;padding:8px 16px;
    font-family:var(--font-body);font-size:.8rem;letter-spacing:.1em;
    transition:top .2s;
}
.skip-link:focus{top:20px;}

/* ===== CURSOR ===== */
.cursor{
    position:fixed;width:8px;height:8px;background:var(--accent);
    border-radius:50%;pointer-events:none;z-index:9999;
    transform:translate(-50%,-50%);transition:transform .1s;
}
.cursor-ring{
    position:fixed;width:36px;height:36px;border:1px solid var(--accent);
    border-radius:50%;pointer-events:none;z-index:9998;
    transform:translate(-50%,-50%);transition:transform .12s,width .25s,height .25s,opacity .25s;
    opacity:.5;
}
body:hover .cursor{opacity:1;}

/* ===== LOADER ===== */
#loader{
    position:fixed;inset:0;background:var(--bg);z-index:10000;
    display:flex;align-items:center;justify-content:center;
    flex-direction:column;gap:16px;
    transition:opacity .8s,visibility .8s;
}
#loader.hidden{opacity:0;visibility:hidden;pointer-events:none;}
.loader-text{
    font-family:var(--font-display);font-size:2rem;font-weight:300;
    letter-spacing:.2em;color:var(--text);
    opacity:0;animation:fadeUp .8s .3s forwards;
}
.loader-bar{width:160px;height:1px;background:var(--border);}
.loader-fill{height:100%;background:var(--accent);width:0;animation:loadBar 1.4s .5s forwards;}
@keyframes loadBar{to{width:100%;}}
@keyframes fadeUp{from{opacity:0;transform:translateY(10px);}to{opacity:1;transform:none;}}

/* ===== NAVIGATION ===== */
header{
    position:fixed;top:0;left:0;right:0;z-index:1000;
    height:var(--nav-h);
    background:transparent;
    transition:background var(--transition),backdrop-filter var(--transition),box-shadow var(--transition);
}
header.scrolled{
    background:rgba(245,242,237,0.92);
    backdrop-filter:blur(20px);
    box-shadow:0 1px 0 var(--border);
}
[data-theme="dark"] header.scrolled{background:rgba(15,13,11,0.92);}

.nav-inner{
    height:100%;display:flex;align-items:center;justify-content:space-between;
    padding:0 40px;max-width:1400px;margin:0 auto;
}
.brand-link{
    font-family:var(--font-display);font-size:1.3rem;font-weight:300;
    letter-spacing:.15em;color:var(--text);
    display:flex;align-items:baseline;gap:6px;
}
.brand-link span{transition:color var(--transition);}
.brand-accent{color:var(--accent);font-style:italic;}

.nav-list{display:flex;gap:36px;align-items:center;}
.nav-list a{
    font-size:.72rem;letter-spacing:.18em;text-transform:uppercase;
    color:var(--text-soft);position:relative;padding-bottom:2px;
    transition:color var(--transition);
}
.nav-list a::after{
    content:'';position:absolute;bottom:0;left:0;width:0;height:1px;
    background:var(--accent);transition:width var(--transition);
}
.nav-list a:hover{color:var(--text);}
.nav-list a:hover::after{width:100%;}

.nav-controls{display:flex;align-items:center;gap:12px;}
.theme-toggle{
    width:36px;height:36px;border-radius:50%;
    display:flex;align-items:center;justify-content:center;
    font-size:1rem;color:var(--text-soft);
    border:1px solid var(--border);
    transition:all var(--transition);
}
.theme-toggle:hover{color:var(--accent);border-color:var(--accent);}

.menu-toggle{
    display:none;flex-direction:column;gap:5px;
    width:32px;padding:4px;
}
.hamburger,.hamburger::before,.hamburger::after{
    display:block;width:24px;height:1px;background:var(--text);
    transition:all .3s;position:relative;
}
.hamburger::before,.hamburger::after{content:'';position:absolute;}
.hamburger::before{top:-7px;}
.hamburger::after{top:7px;}
.menu-toggle.active .hamburger{background:transparent;}
.menu-toggle.active .hamburger::before{transform:rotate(45deg);top:0;}
.menu-toggle.active .hamburger::after{transform:rotate(-45deg);top:0;}

/* ===== PROGRESS BAR ===== */
#scroll-progress{
    position:fixed;top:0;left:0;height:2px;background:var(--accent);
    width:0;z-index:1001;transition:width .1s linear;
}

/* ===== HERO ===== */
.hero{
    min-height:100vh;display:flex;align-items:center;justify-content:center;
    position:relative;overflow:hidden;background:var(--bg);
    padding-top:var(--nav-h);
}
.hero-bg{
    position:absolute;inset:0;
    background:
        radial-gradient(ellipse 80% 60% at 70% 30%, rgba(184,134,11,0.06) 0%, transparent 60%),
        radial-gradient(ellipse 60% 80% at 20% 80%, rgba(139,69,19,0.05) 0%, transparent 50%);
}
.hero-lines{
    position:absolute;inset:0;overflow:hidden;pointer-events:none;
}
.hero-lines::before{
    content:'';position:absolute;top:-20%;right:10%;
    width:1px;height:140%;background:linear-gradient(to bottom,transparent,var(--accent),transparent);
    opacity:.2;animation:lineFloat 8s ease-in-out infinite alternate;
}
.hero-lines::after{
    content:'';position:absolute;bottom:10%;left:15%;
    width:100px;height:1px;background:linear-gradient(to right,transparent,var(--accent),transparent);
    opacity:.3;
}
@keyframes lineFloat{0%{transform:translateY(-20px);}100%{transform:translateY(20px);}}

.hero-content{
    position:relative;z-index:1;text-align:center;
    padding:0 24px;max-width:900px;
}
.hero-eyebrow{
    font-size:.65rem;letter-spacing:.4em;text-transform:uppercase;
    color:var(--accent);margin-bottom:24px;
    opacity:0;animation:fadeUp .8s .8s forwards;
}
.hero-title{
    font-family:var(--font-display);font-size:clamp(3rem,8vw,7rem);
    font-weight:300;line-height:1.05;letter-spacing:.02em;
    color:var(--text);margin-bottom:8px;
    opacity:0;animation:fadeUp .9s 1s forwards;
}
.hero-title em{font-style:italic;color:var(--accent);}
.hero-subtitle{
    font-family:var(--font-display);font-size:clamp(1rem,2.5vw,1.5rem);
    font-weight:300;color:var(--text-soft);letter-spacing:.08em;
    font-style:italic;margin-bottom:48px;
    opacity:0;animation:fadeUp .8s 1.2s forwards;
}
.hero-cta{
    display:inline-flex;align-items:center;gap:12px;
    font-size:.7rem;letter-spacing:.3em;text-transform:uppercase;
    color:var(--text);padding:14px 36px;
    border:1px solid var(--text);position:relative;overflow:hidden;
    opacity:0;animation:fadeUp .8s 1.4s forwards;
    transition:color var(--transition);
}
.hero-cta::before{
    content:'';position:absolute;inset:0;background:var(--text);
    transform:scaleX(0);transform-origin:left;transition:transform var(--transition);
}
.hero-cta:hover::before{transform:scaleX(1);}
.hero-cta:hover{color:var(--bg);}
.hero-cta span{position:relative;z-index:1;}
.hero-cta i{position:relative;z-index:1;transition:transform var(--transition);}
.hero-cta:hover i{transform:translateX(4px);}

.hero-scroll{
    position:absolute;bottom:40px;left:50%;transform:translateX(-50%);
    display:flex;flex-direction:column;align-items:center;gap:8px;
    font-size:.6rem;letter-spacing:.3em;text-transform:uppercase;color:var(--text-soft);
    opacity:0;animation:fadeIn 1s 2s forwards;
}
.scroll-line{
    width:1px;height:40px;background:var(--border);position:relative;overflow:hidden;
}
.scroll-line::after{
    content:'';position:absolute;top:-100%;width:100%;height:50%;
    background:var(--accent);animation:scrollAnim 2s 2.5s infinite;
}
@keyframes scrollAnim{0%{top:-50%;}100%{top:150%;}}
@keyframes fadeIn{to{opacity:1;}}

/* ===== SECTIONS COMMUNES ===== */
section{padding:100px 0;position:relative;}
.container{max-width:1200px;margin:0 auto;padding:0 40px;}
.section-label{
    font-size:.62rem;letter-spacing:.4em;text-transform:uppercase;
    color:var(--accent);margin-bottom:16px;display:block;
}
.section-title{
    font-family:var(--font-display);font-size:clamp(2rem,5vw,3.5rem);
    font-weight:300;line-height:1.1;color:var(--text);margin-bottom:20px;
}
.section-title em{font-style:italic;color:var(--accent);}
.section-desc{
    font-size:.85rem;color:var(--text-soft);max-width:520px;
    letter-spacing:.03em;line-height:1.9;
}
.divider{
    width:40px;height:1px;background:var(--accent);margin:32px 0;
}

/* ===== REVEAL ANIMATIONS ===== */
.reveal{opacity:0;transform:translateY(30px);transition:opacity .8s var(--transition),transform .8s var(--transition);}
.reveal.visible{opacity:1;transform:none;}
.reveal-left{opacity:0;transform:translateX(-40px);transition:opacity .8s var(--transition),transform .8s var(--transition);}
.reveal-left.visible{opacity:1;transform:none;}
.reveal-right{opacity:0;transform:translateX(40px);transition:opacity .8s var(--transition),transform .8s var(--transition);}
.reveal-right.visible{opacity:1;transform:none;}

/* ===== STATS ===== */
.stats{background:var(--bg2);border-top:1px solid var(--border);border-bottom:1px solid var(--border);}
.stats-grid{
    display:grid;grid-template-columns:repeat(4,1fr);
    gap:0;
}
.stat-card{
    padding:56px 40px;text-align:center;
    border-right:1px solid var(--border);
    transition:background var(--transition);
}
.stat-card:last-child{border-right:none;}
.stat-card:hover{background:var(--surface);}
.stat-number{
    font-family:var(--font-display);font-size:clamp(2.5rem,5vw,4rem);
    font-weight:300;color:var(--accent);line-height:1;margin-bottom:8px;
    letter-spacing:-.02em;
}
.stat-suffix{font-size:.6em;opacity:.7;}
.stat-label{
    font-size:.68rem;letter-spacing:.25em;text-transform:uppercase;
    color:var(--text-soft);
}

/* ===== ABOUT ===== */
.about{background:var(--bg);}
.about-inner{
    display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:center;
}
.about-text .section-desc{max-width:100%;}
.about-text p+p{margin-top:16px;}
.features-row{
    display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-top:48px;
}
.feature-item{
    padding:28px 24px;border:1px solid var(--border);
    transition:border-color var(--transition),box-shadow var(--transition),transform var(--transition);
}
.feature-item:hover{border-color:var(--accent);box-shadow:var(--shadow);transform:translateY(-4px);}
.feature-icon{font-size:1.5rem;margin-bottom:12px;display:block;}
.feature-item h4{
    font-family:var(--font-display);font-size:1.1rem;font-weight:400;
    margin-bottom:6px;color:var(--text);
}
.feature-item p{font-size:.75rem;color:var(--text-soft);letter-spacing:.05em;line-height:1.7;}

.about-visual{
    position:relative;
}
.about-frame{
    aspect-ratio:4/5;background:var(--bg2);
    border:1px solid var(--border);position:relative;overflow:hidden;
    display:flex;align-items:center;justify-content:center;
}
.about-frame::before{
    content:'';position:absolute;inset:16px;border:1px solid var(--border);
    pointer-events:none;z-index:1;
}
.about-frame-inner{
    font-family:var(--font-display);font-size:4rem;color:var(--border);
    font-style:italic;user-select:none;
}
.about-tag{
    position:absolute;bottom:-20px;right:-20px;
    background:var(--accent);color:#fff;
    padding:20px 28px;
    font-size:.7rem;letter-spacing:.15em;text-transform:uppercase;
}

/* ===== GALLERY ===== */
.galerie{background:var(--bg2);}
.gallery-header{
    display:flex;flex-direction:column;align-items:center;text-align:center;
    margin-bottom:60px;
}
.filter-bar{
    display:flex;gap:0;border:1px solid var(--border);overflow:hidden;
    margin-top:40px;
}
.filter-btn{
    padding:10px 28px;font-size:.68rem;letter-spacing:.2em;text-transform:uppercase;
    color:var(--text-soft);border-right:1px solid var(--border);
    transition:all var(--transition);font-family:var(--font-body);
    background:transparent;
}
.filter-btn:last-child{border-right:none;}
.filter-btn:hover{color:var(--text);background:var(--surface);}
.filter-btn.active,.filter-btn[aria-pressed="true"]{
    background:var(--text);color:var(--bg);
}

.gallery-section{margin-bottom:80px;}
.gallery-section:last-child{margin-bottom:0;}
.gallery-section-header{
    display:flex;align-items:baseline;justify-content:space-between;
    margin-bottom:32px;padding-bottom:16px;
    border-bottom:1px solid var(--border);
}
.gallery-section-header h3{
    font-family:var(--font-display);font-size:1.8rem;font-weight:300;
    font-style:italic;color:var(--text);
}
.gallery-count{
    font-size:.65rem;letter-spacing:.2em;text-transform:uppercase;color:var(--text-soft);
}

.gallery-grid{
    display:grid;
    grid-template-columns:repeat(3,1fr);
    gap:16px;
}
.gallery-item{
    position:relative;overflow:hidden;cursor:pointer;
    aspect-ratio:4/3;background:var(--bg);
    opacity:0;transform:translateY(20px);
    transition:opacity .5s,transform .5s,box-shadow var(--transition);
}
.gallery-item.in-view{opacity:1;transform:none;}
.gallery-item:hover{box-shadow:var(--shadow-lg);}
.gallery-item img{
    width:100%;height:100%;object-fit:cover;
    transition:transform .6s cubic-bezier(0.25,0.46,0.45,0.94);
    opacity:0;
}
.gallery-item img.loaded{opacity:1;transition:opacity .4s,transform .6s cubic-bezier(0.25,0.46,0.45,0.94);}
.gallery-item:hover img{transform:scale(1.06);}

.gallery-overlay{
    position:absolute;inset:0;background:linear-gradient(to top,rgba(0,0,0,.7) 0%,transparent 50%);
    opacity:0;transition:opacity var(--transition);
    display:flex;align-items:flex-end;padding:20px;
}
.gallery-item:hover .gallery-overlay{opacity:1;}
.overlay-title{
    font-family:var(--font-display);font-size:1rem;font-weight:300;
    color:#fff;font-style:italic;letter-spacing:.05em;
}
.overlay-zoom{
    position:absolute;top:16px;right:16px;width:36px;height:36px;
    border:1px solid rgba(255,255,255,.5);display:flex;align-items:center;justify-content:center;
    color:rgba(255,255,255,.8);font-size:.8rem;
    transform:scale(0);transition:transform var(--transition);
}
.gallery-item:hover .overlay-zoom{transform:scale(1);}

.gallery-controls{
    text-align:center;margin-top:32px;
    display:flex;gap:16px;justify-content:center;
}
.load-more,.show-all{
    padding:10px 32px;font-size:.7rem;letter-spacing:.2em;text-transform:uppercase;
    border:1px solid var(--border);color:var(--text-soft);font-family:var(--font-body);
    transition:all var(--transition);background:transparent;
}
.load-more:hover,.show-all:hover{border-color:var(--accent);color:var(--accent);}
.load-more:disabled,.show-all:disabled{opacity:.3;cursor:default;}

/* ===== LIGHTBOX ===== */
.lightbox{
    position:fixed;inset:0;background:rgba(0,0,0,.96);z-index:5000;
    display:flex;align-items:center;justify-content:center;
    opacity:0;visibility:hidden;transition:opacity .4s,visibility .4s;
}
.lightbox.open{opacity:1;visibility:visible;}
.lightbox-inner{
    position:relative;max-width:90vw;max-height:90vh;
    display:flex;flex-direction:column;align-items:center;
}
.lightbox-inner img{
    max-width:88vw;max-height:80vh;object-fit:contain;
    opacity:0;transition:opacity .4s;
}
.lightbox-inner img.loaded{opacity:1;}
#lightbox-caption{
    font-family:var(--font-display);font-style:italic;
    color:rgba(255,255,255,.7);font-size:1rem;margin-top:16px;
    letter-spacing:.05em;
}
.lb-close{
    position:fixed;top:24px;right:32px;
    width:44px;height:44px;border:1px solid rgba(255,255,255,.2);
    border-radius:50%;color:rgba(255,255,255,.8);font-size:1.2rem;
    display:flex;align-items:center;justify-content:center;
    transition:all .3s;background:transparent;
}
.lb-close:hover{background:rgba(255,255,255,.1);color:#fff;}
.lb-prev,.lb-next{
    position:fixed;top:50%;transform:translateY(-50%);
    width:48px;height:48px;border:1px solid rgba(255,255,255,.2);
    color:rgba(255,255,255,.7);font-size:1.1rem;
    display:flex;align-items:center;justify-content:center;
    transition:all .3s;background:transparent;
}
.lb-prev{left:24px;}
.lb-next{right:24px;}
.lb-prev:hover,.lb-next:hover{background:rgba(255,255,255,.1);color:#fff;}
.lb-counter{
    position:fixed;top:28px;left:50%;transform:translateX(-50%);
    font-size:.65rem;letter-spacing:.3em;text-transform:uppercase;
    color:rgba(255,255,255,.4);
}

/* ===== SERVICES ===== */
.services{background:var(--bg);}
.services-grid{
    display:grid;grid-template-columns:repeat(2,1fr);gap:2px;
    border:2px solid var(--border);margin-top:60px;
}
.service-card{
    padding:48px 44px;border-right:2px solid var(--border);
    border-bottom:2px solid var(--border);
    background:var(--surface);
    transition:background var(--transition);position:relative;overflow:hidden;
}
.service-card:nth-child(even){border-right:none;}
.service-card:nth-last-child(-n+2){border-bottom:none;}
.service-card::before{
    content:'';position:absolute;bottom:0;left:0;height:2px;width:0;
    background:var(--accent);transition:width .5s var(--transition);
}
.service-card:hover::before{width:100%;}
.service-card:hover{background:var(--bg2);}
.service-icon{
    font-size:1.8rem;margin-bottom:20px;display:block;
    line-height:1;
}
.service-card h3{
    font-family:var(--font-display);font-size:1.4rem;font-weight:400;
    color:var(--text);margin-bottom:12px;
}
.service-card>p{
    font-size:.8rem;color:var(--text-soft);line-height:1.9;margin-bottom:20px;
    letter-spacing:.03em;
}
.service-list{display:flex;flex-direction:column;gap:6px;}
.service-list li{
    font-size:.72rem;color:var(--text-soft);letter-spacing:.08em;
    display:flex;align-items:center;gap:8px;
}
.service-list li::before{
    content:'';width:16px;height:1px;background:var(--accent);flex-shrink:0;
}

/* ===== TÉMOIGNAGES ===== */
.testimonials{background:var(--bg2);}
.testi-slider{position:relative;overflow:hidden;margin-top:60px;}
.testi-track{
    display:flex;transition:transform .6s cubic-bezier(0.25,0.46,0.45,0.94);
}
.testi-item{
    min-width:100%;padding:0 80px;text-align:center;
}
.testi-quote{
    font-family:var(--font-display);font-size:clamp(1.2rem,2.5vw,1.7rem);
    font-weight:300;font-style:italic;color:var(--text);
    line-height:1.6;margin-bottom:32px;position:relative;
}
.testi-quote::before{
    content:'"';position:absolute;top:-20px;left:50%;transform:translateX(-50%);
    font-size:5rem;color:var(--accent);opacity:.15;font-style:normal;line-height:1;
}
.testi-author{
    font-size:.72rem;letter-spacing:.2em;text-transform:uppercase;color:var(--text-soft);
}
.testi-author strong{color:var(--accent);}
.testi-dots{
    display:flex;gap:8px;justify-content:center;margin-top:40px;
}
.testi-dot{
    width:6px;height:6px;border-radius:50%;background:var(--border);
    cursor:pointer;transition:background var(--transition),transform var(--transition);
}
.testi-dot.active{background:var(--accent);transform:scale(1.4);}

/* ===== CONTACT ===== */
.contact{background:var(--bg);}
.contact-layout{
    display:grid;grid-template-columns:1fr 1fr;gap:80px;margin-top:60px;
}
.contact-methods{display:flex;flex-direction:column;gap:24px;}
.contact-card{
    padding:28px 32px;border:1px solid var(--border);
    display:flex;align-items:center;gap:20px;
    transition:border-color var(--transition),transform var(--transition),box-shadow var(--transition);
    background:var(--surface);
}
.contact-card:hover{
    border-color:var(--accent);
    transform:translateX(6px);
    box-shadow:var(--shadow);
}
.contact-card-icon{
    width:44px;height:44px;border:1px solid var(--border);
    display:flex;align-items:center;justify-content:center;
    color:var(--accent);font-size:1rem;flex-shrink:0;
    transition:background var(--transition),color var(--transition);
}
.contact-card:hover .contact-card-icon{background:var(--accent);color:#fff;border-color:var(--accent);}
.contact-card-body h4{
    font-family:var(--font-display);font-size:1rem;font-weight:400;
    color:var(--text);margin-bottom:2px;
}
.contact-card-body p,.contact-card-body a{
    font-size:.75rem;color:var(--text-soft);letter-spacing:.05em;
}
.contact-card-body a:hover{color:var(--accent);}

/* ===== CONTACT FORM ===== */
.contact-form{display:flex;flex-direction:column;gap:0;}
.contact-form-title{
    font-family:var(--font-display);font-size:1.8rem;font-weight:300;
    font-style:italic;color:var(--text);margin-bottom:8px;
}
.contact-form-sub{
    font-size:.75rem;color:var(--text-soft);letter-spacing:.05em;margin-bottom:32px;
}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px;}
.form-group{display:flex;flex-direction:column;gap:6px;margin-bottom:16px;}
.form-group label{
    font-size:.65rem;letter-spacing:.2em;text-transform:uppercase;color:var(--text-soft);
}
.form-group input,.form-group textarea,.form-group select{
    padding:12px 16px;background:var(--bg2);border:1px solid var(--border);
    color:var(--text);font-family:var(--font-body);font-size:.85rem;
    transition:border-color var(--transition),box-shadow var(--transition);
    outline:none;border-radius:0;-webkit-appearance:none;
}
.form-group input:focus,.form-group textarea:focus,.form-group select:focus{
    border-color:var(--accent);box-shadow:0 0 0 3px rgba(184,134,11,.08);
}
.form-group textarea{resize:vertical;min-height:120px;}
.form-submit{
    padding:14px 36px;background:var(--text);color:var(--bg);
    font-size:.7rem;letter-spacing:.3em;text-transform:uppercase;
    font-family:var(--font-body);display:flex;align-items:center;gap:12px;
    transition:background var(--transition),transform var(--transition);
    margin-top:8px;align-self:flex-start;
}
.form-submit:hover{background:var(--accent);transform:translateY(-2px);}
.form-submit i{transition:transform var(--transition);}
.form-submit:hover i{transform:translateX(4px);}

.form-status{
    display:none;padding:12px 16px;margin-top:16px;font-size:.8rem;
    border-left:3px solid var(--accent);background:rgba(184,134,11,.06);
    color:var(--text);letter-spacing:.04em;
}
.form-status.show{display:block;}

/* ===== SOCIAL ===== */
.social-section{
    text-align:center;padding:20px 0 0;
}
.social-row{display:flex;gap:12px;justify-content:center;margin-top:20px;}
.social-link{
    width:40px;height:40px;border:1px solid var(--border);
    display:flex;align-items:center;justify-content:center;
    color:var(--text-soft);font-size:.9rem;
    transition:all var(--transition);
}
.social-link:hover{background:var(--text);color:var(--bg);border-color:var(--text);}

/* ===== FOOTER ===== */
footer{
    background:var(--bg2);border-top:1px solid var(--border);
    padding:60px 0 32px;
}
.footer-grid{
    display:grid;grid-template-columns:2fr 1fr 1fr;gap:60px;
    margin-bottom:60px;
}
.footer-brand{
    font-family:var(--font-display);font-size:1.6rem;font-weight:300;
    color:var(--text);margin-bottom:16px;
}
.footer-brand em{font-style:italic;color:var(--accent);}
.footer-desc{font-size:.78rem;color:var(--text-soft);line-height:1.9;max-width:300px;}
.footer-col h5{
    font-size:.65rem;letter-spacing:.3em;text-transform:uppercase;
    color:var(--accent);margin-bottom:20px;
}
.footer-col ul{display:flex;flex-direction:column;gap:10px;}
.footer-col ul a{
    font-size:.78rem;color:var(--text-soft);transition:color var(--transition);
    letter-spacing:.04em;
}
.footer-col ul a:hover{color:var(--text);}
.footer-bottom{
    padding-top:28px;border-top:1px solid var(--border);
    display:flex;align-items:center;justify-content:space-between;
}
.footer-bottom p{font-size:.7rem;color:var(--text-soft);letter-spacing:.08em;}
.footer-bottom a{color:var(--accent);}

/* ===== BACK TO TOP ===== */
#back-to-top{
    position:fixed;bottom:32px;right:32px;z-index:900;
    width:44px;height:44px;border:1px solid var(--border);
    background:var(--surface);color:var(--text-soft);
    display:flex;align-items:center;justify-content:center;
    font-size:.8rem;
    opacity:0;visibility:hidden;
    transition:all var(--transition);
}
#back-to-top.show{opacity:1;visibility:visible;}
#back-to-top:hover{background:var(--accent);color:#fff;border-color:var(--accent);transform:translateY(-3px);}

/* ===== TOAST ===== */
.toast{
    position:fixed;bottom:80px;left:50%;transform:translateX(-50%) translateY(20px);
    background:var(--text);color:var(--bg);
    padding:12px 24px;font-size:.75rem;letter-spacing:.1em;
    opacity:0;transition:all .4s;z-index:9000;pointer-events:none;
}
.toast.show{opacity:1;transform:translateX(-50%) translateY(0);}

/* ===== RESPONSIVE ===== */
@media(max-width:1024px){
    .stats-grid{grid-template-columns:repeat(2,1fr);}
    .stat-card:nth-child(2){border-right:none;}
    .stat-card:nth-child(-n+2){border-bottom:1px solid var(--border);}
    .about-inner{grid-template-columns:1fr;gap:48px;}
    .about-visual{display:none;}
    .footer-grid{grid-template-columns:1fr 1fr;}
    .footer-grid>:first-child{grid-column:1/-1;}
}
@media(max-width:768px){
    :root{--nav-h:60px;}
    .nav-inner{padding:0 20px;}
    .nav-list{
        position:fixed;top:var(--nav-h);left:0;right:0;
        background:var(--bg2);flex-direction:column;padding:24px;gap:20px;
        transform:translateY(-20px);opacity:0;visibility:hidden;
        transition:all var(--transition);border-bottom:1px solid var(--border);
    }
    .nav-list.open{transform:none;opacity:1;visibility:visible;}
    .menu-toggle{display:flex;}
    .hero-title{font-size:clamp(2.2rem,10vw,4rem);}
    .container{padding:0 20px;}
    section{padding:70px 0;}
    .features-row{grid-template-columns:1fr;}
    .gallery-grid{grid-template-columns:repeat(2,1fr);}
    .services-grid{grid-template-columns:1fr;}
    .service-card{border-right:none;}
    .service-card:nth-last-child(-n+2){border-bottom:2px solid var(--border);}
    .service-card:last-child{border-bottom:none;}
    .contact-layout{grid-template-columns:1fr;gap:48px;}
    .form-row{grid-template-columns:1fr;}
    .testi-item{padding:0 20px;}
    .footer-grid{grid-template-columns:1fr;gap:32px;}
    .footer-bottom{flex-direction:column;gap:12px;text-align:center;}
    .stats-grid{grid-template-columns:repeat(2,1fr);}
}
@media(max-width:480px){
    .gallery-grid{grid-template-columns:1fr;}
    .hero-cta{padding:12px 24px;}
    .filter-bar{flex-wrap:wrap;}
    .filter-btn{border-bottom:1px solid var(--border);}
}
