/* ==========================================================
   Cristalería Oteo — sistema visual
   ========================================================== */
:root {
  --ink: #102a2f;
  --ink-deep: #071c20;
  --green: #a8ce3a;
  --green-dark: #7fa524;
  --ice: #eaf1ee;
  --paper: #f8f8f4;
  --white: #fff;
  --muted: #657478;
  --line: rgba(16, 42, 47, .14);
  --shadow: 0 24px 60px rgba(7, 28, 32, .12);
  --radius: 4px;
  --container: 1200px;
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body { margin: 0; color: var(--ink); background: var(--paper); font-family: Inter, Avenir, "Segoe UI", Arial, sans-serif; line-height: 1.6; -webkit-font-smoothing: antialiased; }
body.menu-open { overflow: hidden; }
a { color: inherit; text-decoration: none; }
img, svg { display: block; max-width: 100%; }
button, input, select, textarea { font: inherit; }
.container { width: min(calc(100% - 48px), var(--container)); margin-inline: auto; }
.section { padding: 120px 0; }
.skip-link { position: fixed; left: 16px; top: -80px; z-index: 999; padding: 12px 18px; background: var(--green); color: var(--ink); font-weight: 700; transition: top .2s; }
.skip-link:focus { top: 16px; }

/* Cabecera */
.site-header { position: absolute; inset: 0 0 auto; z-index: 50; color: var(--white); border-bottom: 1px solid rgba(255,255,255,.16); }
.site-header.scrolled { position: fixed; color: var(--ink); background: rgba(248,248,244,.94); box-shadow: 0 8px 30px rgba(7,28,32,.08); backdrop-filter: blur(18px); animation: headerIn .35s ease; }
@keyframes headerIn { from { transform: translateY(-100%); } }
.header-inner { min-height: 92px; display: flex; align-items: center; justify-content: space-between; }
.brand { display: inline-flex; align-items: center; gap: 11px; text-transform: uppercase; }
.brand-mark { width: 36px; color: var(--green); }
.brand-copy { display: flex; flex-direction: column; line-height: 1; }
.brand-copy strong { font-size: 22px; letter-spacing: .12em; }
.brand-copy strong span { color: var(--green); }
.brand-copy small { margin-top: 5px; font-size: 8px; letter-spacing: .38em; opacity: .75; }
.brand-logo { width: 142px; height: 58px; object-fit: contain; }
.brand-logo-dark { display: none; }
.site-header.scrolled .brand-logo-white { display: none; }
.site-header.scrolled .brand-logo-dark { display: block; }
.main-nav { display: flex; align-items: center; gap: 34px; font-size: 13px; font-weight: 650; }
.main-nav > a:not(.nav-cta) { position: relative; }
.main-nav > a:not(.nav-cta)::after { content: ""; position: absolute; left: 0; right: 100%; bottom: -7px; height: 2px; background: var(--green); transition: right .25s; }
.main-nav > a:hover::after, .main-nav > a.active::after { right: 0; }
.nav-cta { padding: 13px 20px; color: var(--ink); background: var(--green); transition: background .2s, transform .2s; }
.nav-cta:hover { background: #bce84a; transform: translateY(-2px); }
.menu-toggle { display: none; width: 42px; height: 42px; padding: 10px; border: 0; background: transparent; color: currentColor; cursor: pointer; }
.menu-toggle span { display: block; height: 2px; margin: 5px 0; background: currentColor; transition: .25s; }

/* Hero */
.hero { min-height: 800px; position: relative; overflow: hidden; color: var(--white); background: var(--ink-deep); }
.hero::before { content: ""; position: absolute; inset: 0; background: radial-gradient(circle at 78% 35%, rgba(90,160,154,.24), transparent 34%), linear-gradient(120deg, transparent 40%, rgba(255,255,255,.025) 40% 41%, transparent 41%); }
.hero-grid { min-height: 800px; position: relative; display: grid; grid-template-columns: .9fr 1.1fr; align-items: center; gap: 70px; padding-top: 100px; }
.hero-copy { min-width: 0; position: relative; z-index: 2; padding: 60px 0; }
.eyebrow { display: flex; align-items: center; gap: 12px; margin: 0 0 24px; color: var(--green-dark); font-size: 11px; font-weight: 800; letter-spacing: .2em; text-transform: uppercase; }
.eyebrow span { width: 30px; height: 2px; background: var(--green); }
.eyebrow.light { color: var(--green); }
h1, h2, h3, p { margin-top: 0; }
h1, h2 { margin-bottom: 28px; font-weight: 500; line-height: .98; letter-spacing: -.045em; }
h1 { max-width: 650px; font-size: clamp(4.2rem, 7vw, 7rem); }
h1 em, h2 em { color: var(--green); font-family: Georgia, "Times New Roman", serif; font-weight: 400; }
.hero-lead { max-width: 570px; margin-bottom: 38px; color: rgba(255,255,255,.72); font-size: 18px; }
.hero-actions { display: flex; flex-wrap: wrap; gap: 14px; }
.button { min-height: 52px; display: inline-flex; align-items: center; justify-content: center; gap: 26px; padding: 14px 22px; border: 1px solid transparent; border-radius: 0; cursor: pointer; font-size: 12px; font-weight: 800; letter-spacing: .04em; transition: transform .2s, background .2s, color .2s; }
.button:hover { transform: translateY(-2px); }
.button-primary { background: var(--green); color: var(--ink-deep); }
.button-primary:hover { background: #bbe64b; }
.button-ghost { border-color: rgba(255,255,255,.3); color: var(--white); }
.button-ghost:hover { background: rgba(255,255,255,.08); }
.trust-list { display: flex; flex-wrap: wrap; gap: 22px; margin: 40px 0 0; padding: 0; list-style: none; color: rgba(255,255,255,.68); font-size: 11px; }
.trust-list .check-mark { width: 10px; height: 6px; display: inline-block; margin: 0 7px 2px 1px; border-left: 2px solid var(--green); border-bottom: 2px solid var(--green); transform: rotate(-45deg); }
.hero-visual { min-width: 0; height: 600px; position: relative; }
.glass-scene { position: absolute; inset: 0; perspective: 900px; }
.glass-panel { position: absolute; border: 1px solid rgba(255,255,255,.32); background: linear-gradient(135deg, rgba(255,255,255,.15), rgba(102,170,174,.04)); box-shadow: inset 0 0 50px rgba(255,255,255,.04), 0 30px 60px rgba(0,0,0,.22); backdrop-filter: blur(3px); transform: skewY(-5deg); }
.panel-one { width: 38%; height: 74%; left: 11%; top: 9%; }
.panel-two { width: 42%; height: 83%; left: 43%; top: 4%; background: linear-gradient(150deg, rgba(168,206,58,.14), rgba(102,170,174,.04) 48%, rgba(255,255,255,.11)); }
.panel-three { width: 23%; height: 55%; right: -2%; top: 22%; }
.scene-lines { position: absolute; inset: 8% 1% 9% 12%; border: 1px solid rgba(255,255,255,.08); transform: skewY(-5deg); }
.scene-lines::before, .scene-lines::after { content: ""; position: absolute; background: rgba(255,255,255,.09); }
.scene-lines::before { width: 1px; height: 100%; left: 51%; }.scene-lines::after { height: 1px; width: 100%; top: 62%; }
.floating-card { position: absolute; right: 2%; bottom: 3%; width: 215px; display: flex; align-items: center; gap: 15px; padding: 20px; color: var(--ink); background: var(--green); box-shadow: var(--shadow); }
.floating-card p { margin: 0; line-height: 1.3; font-size: 12px; }.floating-card strong { font-size: 16px; }.floating-icon { width: 19px; height: 19px; flex: 0 0 19px; border: 2px solid var(--ink); transform: rotate(45deg); }
.scene-caption { position: absolute; left: 0; bottom: 2%; margin: 0; color: rgba(255,255,255,.55); font-size: 10px; letter-spacing: .18em; text-transform: uppercase; }
.scene-caption span { margin-right: 12px; color: var(--green); }
.hero-side-label { position: absolute; right: 15px; bottom: 32px; color: rgba(255,255,255,.28); font-size: 8px; letter-spacing: .25em; writing-mode: vertical-rl; }

/* Títulos y servicios */
.section-heading { display: grid; grid-template-columns: 1.4fr .6fr; align-items: end; gap: 70px; margin-bottom: 65px; }
.section-heading h2, .about h2, .process h2, .contact h2 { font-size: clamp(2.8rem, 5vw, 5rem); }
.section-heading > p { max-width: 420px; margin-bottom: 5px; color: var(--muted); font-size: 15px; }
.service-grid { display: grid; grid-template-columns: repeat(3, 1fr); border-top: 1px solid var(--line); border-left: 1px solid var(--line); }
.service-card { min-height: 370px; position: relative; display: flex; flex-direction: column; padding: 34px; border-right: 1px solid var(--line); border-bottom: 1px solid var(--line); background: rgba(255,255,255,.32); transition: background .3s, transform .3s, box-shadow .3s; }
.service-card:hover { z-index: 2; background: var(--white); box-shadow: var(--shadow); transform: translateY(-6px); }
.service-card.featured { color: var(--white); background: var(--ink); }.service-card.featured p { color: rgba(255,255,255,.62); }
.service-number { align-self: flex-end; color: var(--green-dark); font: italic 13px Georgia, serif; }
.service-icon { width: 58px; height: 58px; position: relative; margin: 28px 0 35px; border: 1px solid var(--line); }
.featured .service-icon { border-color: rgba(255,255,255,.25); }
.service-icon span, .service-icon span::before, .service-icon span::after { position: absolute; content: ""; display: block; border-color: currentColor; }
.icon-shower { width: 27px; height: 35px; left: 15px; top: 11px; border: 1px solid; border-top: 0; }.icon-shower::before { width: 18px; height: 10px; left: 4px; top: -2px; border: 1px solid; border-radius: 50% 50% 0 0; }.icon-shower::after { height: 25px; left: 8px; top: 4px; border-left: 1px dashed; }
.icon-window { inset: 12px; border: 1px solid; }.icon-window::before { inset: 0; border-left: 1px solid; transform: translateX(50%); }.icon-window::after { left: 0; right: 0; top: 50%; border-top: 1px solid; }
.icon-mirror { width: 25px; height: 36px; left: 16px; top: 10px; border: 1px solid; border-radius: 50% 50% 2px 2px; }.icon-mirror::before { width: 10px; height: 1px; right: 4px; top: 8px; background: currentColor; transform: rotate(-45deg); }
.icon-door { inset: 10px 14px; border: 1px solid; }.icon-door::before { width: 3px; height: 3px; right: 4px; top: 50%; border-radius: 50%; background: currentColor; }
.icon-art { inset: 11px; border: 1px solid; transform: rotate(45deg) scale(.72); }.icon-art::before { inset: 7px; border: 1px solid; border-radius: 50%; }.icon-art::after { left: 50%; top: -7px; bottom: -7px; border-left: 1px solid; }
.service-card h3 { margin-bottom: 14px; font-size: 21px; }.service-card p { color: var(--muted); font-size: 13px; }.service-card > a { margin-top: auto; font-size: 11px; font-weight: 800; }.service-card > a span { float: right; color: var(--green-dark); font-size: 18px; }
.service-cta { justify-content: center; color: var(--white); background: var(--green-dark); }.service-cta .eyebrow { color: var(--white); }.service-cta .eyebrow span { background: var(--white); }.service-cta h3 { max-width: 230px; font-size: 29px; line-height: 1.2; }.circle-link { width: auto; min-width: 82px; height: 42px; display: grid; place-items: center; margin: 15px 0 0 !important; padding: 0 18px; border: 1px solid rgba(255,255,255,.65); border-radius: 0; font-size: 10px !important; letter-spacing: .08em; text-transform: uppercase; }

/* Nosotros */
.about { background: var(--ice); }
.about-grid { display: grid; grid-template-columns: 1fr 1fr; align-items: center; gap: 9%; }
.about-visual { min-height: 600px; position: relative; }
.workshop-art { position: absolute; inset: 0 8% 8% 0; overflow: hidden; background: linear-gradient(140deg,#4d6868,#c4d0c6 54%,#8ca49f); box-shadow: var(--shadow); }
.workshop-art::before { content: ""; position: absolute; inset: 0; background: repeating-linear-gradient(110deg,transparent 0 85px,rgba(255,255,255,.09) 85px 87px); }
.measure-line { position: absolute; z-index: 4; top: 12%; left: 8%; right: 8%; height: 1px; background: rgba(255,255,255,.75); }.measure-line::before,.measure-line::after { content:""; position:absolute; top:-5px; height:11px; border-left:1px solid white; }.measure-line::after { right:0; }.measure-line span { position:absolute; top:-25px; left:45%; color:white; font-size:9px; letter-spacing:.15em; }
.art-pane { position: absolute; border: 2px solid rgba(255,255,255,.65); background: rgba(210,235,229,.18); box-shadow: 20px 25px 40px rgba(21,52,51,.18); backdrop-filter: blur(2px); }.pane-a { width: 45%; height: 65%; left: 14%; top: 20%; transform: rotate(-7deg); }.pane-b { width: 42%; height: 60%; left: 42%; top: 28%; transform: rotate(8deg); }.art-shadow { position:absolute; width:80%; height:10%; left:10%; bottom:2%; background:rgba(9,35,35,.25); filter:blur(18px); }
.experience-badge { position: absolute; right: 0; bottom: 0; width: 185px; height: 185px; display: flex; flex-direction: column; justify-content: center; padding: 28px; color: var(--ink); background: var(--green); }.experience-badge strong { font-size: 44px; line-height: 1; }.experience-badge span { margin-top: 8px; font-size: 11px; font-weight: 700; line-height: 1.4; text-transform: uppercase; }
.about-copy h2 { max-width: 630px; }.large-copy { font-size: 20px; line-height: 1.5; }.about-copy > p:not(.eyebrow) { max-width: 570px; color: var(--muted); }
.about-values { display: grid; grid-template-columns: repeat(3,1fr); margin: 40px 0; border-top: 1px solid var(--line); border-bottom: 1px solid var(--line); }.about-values div { display:flex; gap:14px; padding:22px 10px; border-right:1px solid var(--line); }.about-values div:last-child { border:0; }.about-values strong { color: var(--green-dark); font: italic 12px Georgia,serif; }.about-values span { font-size:11px; font-weight:700; line-height:1.35; text-transform:uppercase; }
.text-link { display:inline-flex; gap:40px; padding-bottom:5px; border-bottom:1px solid var(--ink); font-size:12px; font-weight:800; }.text-link span { color:var(--green-dark); font-size:18px; }

/* Proceso */
.process { color: var(--white); background: var(--ink); }
.process-heading { display:flex; justify-content:space-between; align-items:flex-start; gap:50px; margin-bottom:70px; }.process-heading h2 { margin:0; max-width:760px; }
.process-list { display:grid; grid-template-columns:repeat(4,1fr); margin:0; padding:0; border-top:1px solid rgba(255,255,255,.18); list-style:none; }.process-list li { min-height:220px; padding:25px 28px; border-right:1px solid rgba(255,255,255,.18); }.process-list li:first-child { border-left:1px solid rgba(255,255,255,.18); }.process-list > li > span { color:var(--green); font:italic 13px Georgia,serif; }.process-list div { margin-top:60px; }.process-list h3 { margin-bottom:10px; font-size:17px; }.process-list p { color:rgba(255,255,255,.55); font-size:12px; }

/* Trabajos: ilustraciones CSS autocontenidas */
.project-grid { display:grid; grid-template-columns:repeat(2,1fr); gap:24px; }.project { overflow:hidden; background:var(--white); box-shadow:0 12px 40px rgba(7,28,32,.06); }.project-art { height:380px; position:relative; overflow:hidden; transition:transform .6s ease; }.project:hover .project-art, .project:focus .project-art { transform:scale(1.025); }.project-meta { display:flex; justify-content:space-between; align-items:center; padding:24px 26px; }.project-meta p { margin-bottom:4px; color:var(--green-dark); font-size:9px; font-weight:800; letter-spacing:.16em; text-transform:uppercase; }.project-meta h3 { margin:0; font-size:18px; }.project-meta > span { font-size:22px; }
.project-large { grid-row:span 2; }.project-large .project-art { height:720px; }.project-wide { grid-column:2; }
.bathroom { background:linear-gradient(115deg,#d2d8d3 0 28%,#f6f2e9 28% 64%,#bdc8c3 64%); }.bathroom::before { content:""; position:absolute; left:8%; bottom:0; width:55%; height:38%; background:linear-gradient(#fff,#d7d9d5); border-radius:50% 50% 0 0/18% 18% 0 0; box-shadow:inset 0 15px 20px rgba(0,0,0,.07); }.bathroom .art-frame { position:absolute; inset:8% 7% 6% 38%; border:5px solid #273a3c; border-bottom:0; }.bathroom .art-glass { position:absolute; inset:8% 7% 6% 65%; border:1px solid rgba(255,255,255,.8); background:linear-gradient(120deg,rgba(255,255,255,.22),rgba(103,169,174,.05)); }.bathroom .art-light { position:absolute; width:9%; height:35%; right:15%; top:16%; background:rgba(255,255,255,.5); filter:blur(10px); transform:skew(-18deg); }
.divider { background:linear-gradient(110deg,#d6d0c1,#7e8a7d); }.divider-grid { position:absolute; inset:0 14% 0 22%; border:9px solid #152b2e; background:linear-gradient(90deg,rgba(199,225,218,.16),rgba(255,255,255,.1)); }.divider-grid::before { content:""; position:absolute; inset:0; background:linear-gradient(90deg,transparent 48.5%,#152b2e 48.5% 51.5%,transparent 51.5%),linear-gradient(transparent 48.5%,#152b2e 48.5% 51.5%,transparent 51.5%); }.plant { position:absolute; width:70px; height:130px; right:5%; bottom:0; border-radius:50% 0; background:#3d5947; transform:rotate(-15deg); opacity:.75; }
.mirror { background:linear-gradient(125deg,#b7a98f,#ece6dc 60%,#aca390); }.mirror-arch { position:absolute; left:24%; top:7%; width:48%; height:82%; border:8px solid #273f3e; border-radius:50% 50% 2px 2px; background:linear-gradient(145deg,rgba(207,228,223,.75),rgba(104,137,135,.38)); box-shadow:12px 20px 30px rgba(0,0,0,.15); }.mirror-arch::before { content:""; position:absolute; width:60%; height:10%; left:20%; top:18%; background:rgba(255,255,255,.35); filter:blur(8px); transform:rotate(-25deg); }.mirror-table { position:absolute; left:10%; right:10%; bottom:4%; height:16%; background:#735c45; box-shadow:0 -8px 0 #403c35; }
.stained { height:310px; display:flex; background:#193638; }.stained span { flex:1; margin-right:3px; clip-path:polygon(0 0,100% 7%,85% 100%,10% 92%); }.stained span:nth-child(1) { background:#aecf3c; }.stained span:nth-child(2) { background:#6aa7a1; }.stained span:nth-child(3) { background:#e0c86f; }.stained span:nth-child(4) { background:#e9eee8; }.stained span:nth-child(5) { background:#508078; }

/* Contacto */
.contact { color:var(--white); background:var(--ink-deep); }.contact-wrap { display:grid; grid-template-columns:.85fr 1.15fr; gap:10%; align-items:start; }.contact-copy > p:not(.eyebrow) { max-width:520px; color:rgba(255,255,255,.62); }.contact-direct { margin-top:55px; }.contact-direct a { display:block; padding:22px 0; border-top:1px solid rgba(255,255,255,.18); }.contact-direct a:last-child { border-bottom:1px solid rgba(255,255,255,.18); }.contact-direct span { display:block; margin-bottom:4px; color:var(--green); font-size:9px; letter-spacing:.18em; text-transform:uppercase; }.contact-direct strong { font-size:17px; font-weight:500; }
.contact-form { padding:46px; color:var(--ink); background:var(--paper); box-shadow:var(--shadow); }.field-row { display:grid; grid-template-columns:1fr 1fr; gap:22px; }.contact-form label { display:block; margin-bottom:23px; font-size:10px; font-weight:800; letter-spacing:.08em; text-transform:uppercase; }.contact-form input,.contact-form select,.contact-form textarea { width:100%; margin-top:8px; padding:12px 2px; border:0; border-bottom:1px solid rgba(16,42,47,.3); outline:0; color:var(--ink); background:transparent; font-size:14px; font-weight:400; text-transform:none; transition:border .2s; }.contact-form textarea { resize:vertical; }.contact-form input:focus,.contact-form select:focus,.contact-form textarea:focus { border-color:var(--green-dark); }.contact-form .button { width:100%; border:0; }.form-note { margin:12px 0 0; color:var(--muted); font-size:10px; text-align:center; }
.location { padding:60px 0; background:var(--green); }.location-grid { display:grid; grid-template-columns:1fr 1fr auto; align-items:center; gap:45px; }.location-block { display:flex; gap:20px; }.location-block > span { font:italic 12px Georgia,serif; }.location-block p { margin-bottom:5px; font-size:9px; font-weight:800; letter-spacing:.16em; text-transform:uppercase; }.location-block address,.location-block a { font-size:13px; font-style:normal; }.map-link { display:flex; align-items:center; gap:45px; padding:15px 20px; border:1px solid var(--ink); font-size:11px; font-weight:800; }.map-link span { font-size:20px; }

/* Pie */
.site-footer { padding:65px 0 20px; color:var(--white); background:var(--ink); }.footer-main { display:grid; grid-template-columns:1fr 1fr 1fr; align-items:start; gap:50px; padding-bottom:60px; }.brand-light { color:white; }.footer-main > p { color:rgba(255,255,255,.5); font-size:12px; }.footer-main nav { display:grid; grid-template-columns:1fr 1fr; gap:12px; font-size:12px; }.footer-main nav a:hover { color:var(--green); }.footer-bottom { display:flex; justify-content:space-between; padding-top:18px; border-top:1px solid rgba(255,255,255,.15); color:rgba(255,255,255,.38); font-size:9px; letter-spacing:.12em; text-transform:uppercase; }.footer-bottom p { margin:0; }
.floating-call { display:none; }

/* Animación progresiva */
.js .reveal { opacity:0; transform:translateY(28px); transition:opacity .75s ease,transform .75s ease; }.js .reveal.visible { opacity:1; transform:none; }
@media (prefers-reduced-motion: reduce) { html { scroll-behavior:auto; } *,*::before,*::after { animation-duration:.01ms!important; transition-duration:.01ms!important; } .js .reveal { opacity:1; transform:none; } }

/* Responsive */
@media (max-width: 980px) {
  .section { padding:90px 0; }.hero-grid { grid-template-columns:1fr 1fr; gap:25px; }.hero-visual { height:520px; }.service-grid { grid-template-columns:repeat(2,1fr); }.about-grid { gap:6%; }.about-visual { min-height:500px; }.process-heading { display:block; }.process-list { grid-template-columns:repeat(2,1fr); }.contact-wrap { gap:5%; }.location-grid { grid-template-columns:1fr 1fr; }.map-link { grid-column:1/-1; justify-content:space-between; }
}
@media (max-width: 760px) {
  .container { width:min(calc(100% - 32px),var(--container)); }.section { padding:72px 0; }.header-inner { min-height:74px; }.menu-toggle { display:block; z-index:3; }.menu-toggle[aria-expanded="true"] span:nth-child(1) { transform:translateY(7px) rotate(45deg); }.menu-toggle[aria-expanded="true"] span:nth-child(2) { opacity:0; }.menu-toggle[aria-expanded="true"] span:nth-child(3) { transform:translateY(-7px) rotate(-45deg); }
  .main-nav { position:fixed; inset:0; display:flex; flex-direction:column; align-items:flex-start; justify-content:center; gap:24px; padding:75px 12%; color:white; background:rgba(7,28,32,.98); transform:translateX(100%); transition:transform .35s ease; }.main-nav.open { transform:none; }.main-nav a { font-size:25px; }.main-nav .nav-cta { font-size:14px; }
  .brand-logo { width: 124px; height: 50px; }
  .hero,.hero-grid { min-height:780px; }.hero-grid { grid-template-columns:minmax(0,1fr); padding-top:105px; }.hero-copy { width:100%; padding:35px 0 10px; }.hero h1 { max-width:100%; font-size:clamp(3.35rem,16vw,5.8rem); }.hero-lead { max-width:100%; font-size:16px; }.trust-list { gap:10px 18px; }.hero-visual { width:100%; height:270px; }.panel-one { height:72%; }.panel-two { height:82%; }.panel-three { height:60%; }.floating-card { width:165px; padding:13px; }.floating-icon { font-size:22px; }.floating-card strong { font-size:13px; }.scene-caption { bottom:-2%; }.hero-side-label { display:none; }
  .section-heading { grid-template-columns:1fr; gap:12px; margin-bottom:40px; }.section-heading h2,.about h2,.process h2,.contact h2 { font-size:clamp(2.65rem,13vw,4rem); }.service-grid { grid-template-columns:1fr; }.service-card { min-height:330px; padding:28px; }
  .about-grid { grid-template-columns:1fr; }.about-visual { min-height:450px; }.workshop-art { inset:0 6% 8% 0; }.experience-badge { width:145px; height:145px; padding:20px; }.experience-badge strong { font-size:34px; }.about-values div { flex-direction:column; gap:8px; padding:18px 8px; }
  .process-heading { margin-bottom:45px; }.process-list { grid-template-columns:1fr; }.process-list li { min-height:160px; display:grid; grid-template-columns:45px 1fr; padding:25px 18px; border-left:1px solid rgba(255,255,255,.18); }.process-list div { margin-top:0; }
  .project-grid { grid-template-columns:1fr; }.project-large,.project-wide { grid-column:auto; grid-row:auto; }.project-art,.project-large .project-art { height:420px; }.stained { height:300px; }
  .contact-wrap { grid-template-columns:1fr; gap:45px; }.contact-direct { margin-top:35px; }.contact-direct strong { font-size:14px; overflow-wrap:anywhere; }.contact-form { padding:28px 22px; }.field-row { grid-template-columns:1fr; gap:0; }.location-grid { grid-template-columns:1fr; gap:28px; }.map-link { grid-column:auto; }.footer-main { grid-template-columns:1fr; gap:28px; }.footer-main > p { margin:0; }.footer-bottom { gap:20px; }.floating-call { position:fixed; z-index:40; right:14px; bottom:14px; display:flex; align-items:center; gap:8px; padding:12px 16px; color:var(--ink); background:var(--green); box-shadow:0 8px 28px rgba(0,0,0,.22); font-size:11px; }.floating-call span { font-size:16px; }
}
@media (max-width: 390px) { .hero-actions .button { width:100%; }.about-values { grid-template-columns:1fr; }.about-values div { flex-direction:row; border-right:0; border-bottom:1px solid var(--line); }.project-art,.project-large .project-art { height:350px; }.footer-bottom { display:block; }.footer-bottom p + p { margin-top:8px; } }

/* ==========================================================
   Fotografías originales y catálogo Profiltek
   ========================================================== */
.hero-photo { inset: 5% 0 4%; overflow: hidden; box-shadow: 0 35px 80px rgba(0,0,0,.32); }
.hero-photo::after { content: ""; position: absolute; inset: 0; background: linear-gradient(90deg,rgba(7,28,32,.18),transparent 50%),linear-gradient(0deg,rgba(7,28,32,.52),transparent 42%); pointer-events: none; }
.hero-photo > img { width: 100%; height: 100%; object-fit: cover; filter: saturate(.72) contrast(1.08); }
.hero-photo .scene-lines,.hero-photo .floating-card,.hero-photo .scene-caption { z-index: 2; }

.service-photo-strip { display: grid; grid-template-columns: repeat(3,1fr); gap: 18px; margin-top: 34px; }
.service-photo-strip figure { height: 220px; position: relative; overflow: hidden; margin: 0; background: var(--ink); }
.service-photo-strip figure::after { content: ""; position: absolute; inset: 0; background: linear-gradient(0deg,rgba(7,28,32,.8),transparent 65%); }
.service-photo-strip img { width: 100%; height: 100%; object-fit: cover; filter: saturate(.72); transition: transform .5s ease; }
.service-photo-strip figure:hover img { transform: scale(1.045); }
.service-photo-strip figcaption { position: absolute; z-index: 2; left: 22px; bottom: 18px; color: white; font-size: 12px; font-weight: 800; letter-spacing: .12em; text-transform: uppercase; }

.catalog { overflow: hidden; background: var(--white); }
.catalog-grid { display: grid; grid-template-columns: .72fr 1.28fr; align-items: center; gap: 10%; }
.catalog-cover { width: min(100%,390px); position: relative; justify-self: center; padding: 28px; background: var(--ice); box-shadow: var(--shadow); transform: rotate(-2deg); transition: transform .3s ease; }
.catalog-cover:hover { transform: rotate(0) translateY(-6px); }
.catalog-cover::before { content: ""; position: absolute; width: 70%; height: 80%; right: -18%; top: 12%; z-index: -1; border: 1px solid var(--green); }
.catalog-cover img { width: 100%; max-height: 560px; object-fit: contain; background: white; }
.catalog-cover > span { display: flex; justify-content: space-between; align-items: center; padding-top: 18px; font-size: 11px; font-weight: 800; text-transform: uppercase; }
.catalog-cover strong { color: var(--green-dark); font-size: 22px; }
.catalog-copy h2 { max-width: 710px; font-size: clamp(2.8rem,5vw,5rem); }
.catalog-copy > p:not(.eyebrow) { max-width: 650px; color: var(--muted); }
.catalog-actions { display: flex; flex-wrap: wrap; gap: 12px; margin: 35px 0; }
.button-dark { border-color: var(--ink); color: var(--white); background: var(--ink); }
.button-dark:hover { background: var(--ink-deep); }
.catalog-detail { display: flex; align-items: center; gap: 25px; padding-top: 22px; border-top: 1px solid var(--line); }
.catalog-detail > span { color: var(--green-dark); font-size: 11px; font-weight: 900; letter-spacing: .2em; }
.catalog-detail p { margin: 0; color: var(--muted); font-size: 12px; }

.workshop-photo::before { z-index: 1; background: linear-gradient(0deg,rgba(7,28,32,.28),transparent 55%); }
.workshop-photo img { width: 100%; height: 100%; object-fit: cover; filter: saturate(.8) contrast(1.04); }

.real-gallery figure { margin: 0; }
.real-gallery .project { display: flex; flex-direction: column; }
.real-gallery .project > img { width: 100%; height: 380px; object-fit: cover; flex: 1; min-height: 0; transition: transform .55s ease,filter .55s ease; }
.real-gallery .project-large > img { height: 720px; }
.real-gallery .project-wide > img { height: 310px; }
.real-gallery .project:hover > img { transform: scale(1.035); filter: contrast(1.04); }
.real-gallery .project-meta { position: relative; z-index: 2; flex: 0 0 auto; background: var(--white); }
.real-gallery .project-meta > span { color: var(--green-dark); font: italic 13px Georgia,serif; }

.call-panel { position: relative; min-height: 520px; overflow: hidden; background: var(--ice); box-shadow: var(--shadow); }
.call-panel::after { content: ""; position: absolute; inset: 0; background: linear-gradient(0deg,rgba(7,28,32,.92),rgba(7,28,32,.08) 68%); }
.call-panel > img { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; filter: saturate(.75); }
.call-panel > div { position: absolute; z-index: 2; left: 38px; right: 38px; bottom: 38px; }
.call-panel p { margin-bottom: 8px; color: var(--green); font-size: 10px; font-weight: 800; letter-spacing: .16em; text-transform: uppercase; }
.call-panel strong { display: block; margin-bottom: 24px; color: var(--white); font-size: 28px; line-height: 1.15; }

@media (max-width:980px) { .catalog-grid { gap: 6%; } }
@media (max-width:760px) {
  .service-photo-strip { grid-template-columns: 1fr; }
  .service-photo-strip figure { height: 190px; }
  .catalog-grid { grid-template-columns: 1fr; gap: 65px; }
  .catalog-cover { max-width: 300px; }
  .catalog-copy h2 { font-size: clamp(2.65rem,13vw,4rem); }
  .catalog-actions .button { width: 100%; }
  .real-gallery .project > img,.real-gallery .project-large > img,.real-gallery .project-wide > img { height: 420px; }
  .call-panel { min-height: 440px; }
  .call-panel > div { left: 24px; right: 24px; bottom: 24px; }
  .contact-direct strong { font-size: 22px; }
}
