/* Base y utilidades */
:root{--granate:#7A0E21;--granate-2:#5E0B18;--bone:#F7F4EF;--ink:#121212;--meta:#6F6F6F;--radius:16px;--shadow:0 12px 28px rgba(0,0,0,.12)}
/* Utilidades para reemplazar estilos inline */
.init-hidden{display:none}
.footer{padding:36px 0;border-top:1px solid rgba(0,0,0,.06)}
.flex-between{display:flex;flex-wrap:wrap;gap:10px;align-items:center;justify-content:space-between}
.flex-gap-10{display:flex;gap:10px}
.banner-row{display:flex;gap:12px;align-items:center;justify-content:space-between;padding:12px 0;flex-wrap:wrap}
.legal-overlay{position:fixed;inset:0;background:rgba(0,0,0,.55);z-index:140;align-items:center;justify-content:center;padding:4vh;display:none}
.legal-dialog{width:min(1100px,96vw);max-height:88vh;overflow:auto;background:var(--bone);border-radius:16px;padding:18px;border:1px solid rgba(0,0,0,.08)}
.legal-header{display:flex;justify-content:space-between;align-items:center;gap:10px;position:sticky;top:0;background:var(--bone);padding-bottom:8px}
.legal-title{margin:0}
.article-mt{margin-top:8px}
.muted-spaced{margin:.2rem 0 1rem}
.sep{border:none;border-top:1px solid rgba(0,0,0,.08);margin:16px 0}
.list-indent{margin:.2rem 0 0 1.1rem}
.cookie-actions{display:flex;gap:10px}
.quote{margin:.4rem 0 0}
.visually-hidden-field{position:absolute;left:-10000px;opacity:0}
.span-all{grid-column:1 / -1}
/* === Global base (antes en <head>) === */
:root{--granate:#7A0E21;--granate-2:#5E0B18;--bone:#F7F4EF;--ink:#121212;--meta:#6F6F6F;--radius:16px;--shadow:0 12px 28px rgba(0,0,0,.12)}
*{box-sizing:border-box}
html{scroll-behavior:smooth;overflow-x:hidden}
body{margin:0;color:var(--ink);background:var(--bone);font:400 16px/1.6 "DM Serif Text",Georgia,serif;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;overflow-x:hidden;min-width:320px}
body.menu-open{overflow:hidden;position:fixed;width:100%}
img{max-width:100%;height:auto;display:block}
a{color:inherit;text-decoration:none}
.container{width:min(1200px,92vw);margin-inline:auto;overflow-x:hidden}
h1,h2,h3{font-family:"DM Serif Text",Georgia,serif;line-height:1.2;margin:0 0 .4em;font-weight:500}
h1{font-size:clamp(36px,6vw,64px)}
h2{font-size:clamp(24px,3.6vw,40px)}
h2::after{content:"";display:block;width:52px;height:4px;border-radius:4px;background:var(--granate);margin-top:6px}
h3{font-size:clamp(18px,2.2vw,24px)}
.sub{color:var(--meta)}
.btn{display:inline-flex;align-items:center;gap:.6rem;padding:.9rem 1.1rem;border-radius:12px;border:1px solid rgba(0,0,0,.08);transition:.2s transform,.2s filter,.2s box-shadow;font-weight:500;font-family:"DM Serif Text",Georgia,serif}
.btn:hover{transform:translateY(-2px)}
.btn-primary{background:var(--granate);color:#fff;border:none;box-shadow:var(--shadow)}
.btn-primary:hover{filter:brightness(.95)}
.btn-ghost{background:#fff;color:var(--granate);border-color:var(--granate)}
.btn-ghost:hover{background:rgba(122,14,33,.08)}
.cta-row{display:flex;gap:10px;flex-wrap:wrap}
@media (max-width:700px){.cta-row{justify-content:center}}
@media (max-width:480px){.btn{padding:.8rem 1rem;font-size:15px}.cta-row{flex-direction:column;gap:8px}.cta-row .btn{width:100%;justify-content:center}}
.chip{display:inline-flex;align-items:center;gap:.4rem;padding:.35rem .7rem;border-radius:999px;border:1px solid rgba(0,0,0,.08);background:#fff;color:#572;font-weight:500;font-family:"DM Serif Text",Georgia,serif}
.chip:hover{border-color:var(--granate);color:var(--granate)}
.chip[data-active="true"]{background:var(--granate);color:#fff;border-color:var(--granate)}
.grid{display:grid;gap:18px}
.grid.cols-3{grid-template-columns:repeat(3,1fr)}
.grid.cols-2{grid-template-columns:repeat(2,1fr)}
@media (max-width:1100px){.grid.cols-3{grid-template-columns:repeat(2,1fr)}}
@media (max-width:700px){.grid.cols-3,.grid.cols-2{grid-template-columns:1fr}}
header.site{position:sticky;top:0;z-index:50;background:rgba(247,244,239,.7);backdrop-filter:blur(8px);border-bottom:1px solid rgba(0,0,0,.06)}
.nav{display:flex;align-items:center;justify-content:space-between;padding:.8rem 0}
.brand{display:flex;align-items:center;gap:.6rem}
.brand-logo{height:50px;width:auto;image-rendering:auto;transition:transform .2s ease;filter:brightness(1);opacity:1}
.brand-logo:hover{transform:scale(1.05)}
@media (min-width:768px){.brand-logo{height:60px}}
@media (min-width:1000px){.brand-logo{height:70px}}
@media (max-width:480px){.brand-logo{height:45px}}
.brand .name{font-weight:500;font-family:"DM Serif Text",Georgia,serif}
.menu{display:flex;align-items:center;gap:.6rem;flex-wrap:wrap}
.menu a{padding:.5rem .7rem;border-radius:10px;font-size:15px;font-family:"DM Serif Text",Georgia,serif}
.menu a:hover{background:rgba(122,14,33,.08);color:var(--granate)}
.hamburger{display:none;border:none;padding:.5rem;border-radius:10px;background:rgba(255,255,255,.9);color:var(--granate);cursor:pointer;transition:all .2s ease;width:40px;height:40px;display:grid;place-items:center;font-size:16px;font-weight:600;backdrop-filter:blur(8px);box-shadow:0 2px 8px rgba(0,0,0,.1)}
@media (min-width:881px){.hamburger{display:none !important}}
.hamburger:hover{background:var(--granate);color:#fff;transform:translateY(-1px);box-shadow:0 4px 12px rgba(122,14,33,.25)}
.hamburger:active{transform:translateY(0)}
@media (max-width:880px){.hamburger{display:inline-flex}.menu{position:fixed;inset:64px 4vw auto 4vw;background:rgba(247,244,239,.97);backdrop-filter:blur(8px);border:1px solid rgba(0,0,0,.06);border-radius:12px;padding:10px;display:none;opacity:0;transform:translateY(-10px);transition:opacity .2s ease,transform .2s ease}.menu[aria-expanded="true"]{display:flex;flex-direction:column;gap:4px;opacity:1;transform:translateY(0)}}
@media (max-width:480px){.nav{padding:.6rem 0}.brand-logo{height:40px}.hamburger{width:36px;height:36px;font-size:14px;padding:.4rem}.menu{inset:56px 3vw auto 3vw;padding:12px}.menu a{padding:.7rem 1rem;font-size:16px}}
.elev{box-shadow:0 10px 30px rgba(0,0,0,.06)}
section.hero{position:relative;overflow:hidden}
.hero::before{content:"";position:absolute;inset:auto -10% -30% -10%;height:60%;background:radial-gradient(60% 60% at 70% 40%,#7a0e2120 0%,transparent 60%);z-index:0;pointer-events:none}
.hero .monogram{display:none}
.hero .inner{position:relative;z-index:1;display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(16px,3vw,36px);align-items:center;padding:clamp(24px,6vw,64px) 0}
.hero .portrait{border-radius:20px;overflow:hidden;background:linear-gradient(#fff,#fff),radial-gradient(60% 60% at 50% 30%,#7a0e2120,transparent 70%);background-clip:padding-box;border:1px solid rgba(0,0,0,.06);padding:8px;box-shadow:var(--shadow)}
.hero .portrait{max-width:min(560px,46vw)}
.hero .portrait img{width:100%;height:auto;object-fit:contain;display:block}
.hero .chips{display:flex;flex-wrap:wrap;gap:8px;margin:.6rem 0 1rem}
.socials{display:flex;gap:10px;margin:.6rem 0}
.icon{width:22px;height:22px;display:inline-block}
@media (max-width:900px){.hero .inner{grid-template-columns:1fr;padding:24px 0;align-items:center}.hero .portrait{order:-1;margin:8px auto 0;max-width:min(520px,88vw)}.hero::before{display:none}}
@media (max-width:700px){.hero .inner{display:flex;flex-direction:column;gap:16px}.hero .inner>div[data-reveal]{text-align:center}.hero .chips{justify-content:center}.socials{justify-content:center}}
section{padding:60px 0;border-top:1px solid rgba(0,0,0,.06)}
.filters{display:flex;gap:8px;flex-wrap:wrap;margin:.6rem 0 1rem}
.card{background:#fff;border:1px solid rgba(0,0,0,.06);border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow);display:flex;flex-direction:column;min-height:100%}
.hidden{display:none !important}
.modal{position:fixed;inset:0;background:rgba(0,0,0,.55);display:none;z-index:100;align-items:center;justify-content:center;padding:4vh}
.modal[aria-hidden="false"]{display:flex}
.dialog{width:min(1100px,96vw);display:grid;grid-template-columns:1.2fr .8fr;gap:16px;background:var(--bone);border-radius:16px;overflow:hidden}
.dialog video{width:100%;height:auto;background:#000}
.dialog .pane{padding:16px 16px 18px;overflow:auto;max-height:80vh}
.close{position:absolute;top:10px;right:10px;background:#fff;border:1px solid rgba(0,0,0,.1);border-radius:10px;padding:.4rem .6rem}
@media (max-width:900px){.dialog{grid-template-columns:1fr}.pane{max-height:60vh}}
.kv{display:grid;grid-template-columns:auto 1fr;gap:6px 10px;margin:.4rem 0}
.kv b{color:var(--meta)}
.plan{padding:18px;display:flex;flex-direction:column;gap:10px}
.plan h3{margin-bottom:0}
.plan ul{margin:.2rem 0 0 1.1rem}
.plan .extra{display:inline-block;margin-top:6px;background:#fff3;border:1px dashed var(--granate);padding:.25rem .5rem;border-radius:8px;color:var(--granate);font-weight:600}
.steps{display:grid;gap:12px;grid-template-columns:repeat(6,1fr)}
.step{background:#fff;border:1px solid rgba(0,0,0,.06);border-radius:12px;padding:14px;text-align:center}
.step .n{display:inline-grid;place-items:center;width:32px;height:32px;background:var(--granate);color:#fff;border-radius:999px;font-weight:700;margin-bottom:8px}
@media (max-width:1000px){.steps{grid-template-columns:repeat(3,1fr)}}
@media (max-width:600px){.steps{grid-template-columns:repeat(2,1fr)}}
@media (max-width:480px){.steps{gap:10px}.step{padding:12px}.step .n{width:28px;height:28px;font-size:14px}}
#marcas{background:#fff;padding:80px 0;color:var(--ink)}
#marcas h2{color:var(--granate);text-align:center;margin:0 0 16px}
.brands-carousel{position:relative;width:min(1200px,92vw);margin:0 auto;overflow:hidden;mask:linear-gradient(90deg,transparent,white 20%,white 80%,transparent);-webkit-mask:linear-gradient(90deg,transparent,white 20%,white 80%,transparent)}
.brands-track{display:flex;gap:22px;width:max-content;animation:scroll-brands 30s linear infinite;will-change:transform}
.brands-track:hover{animation-play-state:paused}
.brand-item{flex:0 0 auto;width:220px;height:220px;display:grid;place-items:center;background:transparent;border-radius:16px;border:1px solid rgba(122,14,33,.18);transition:transform .3s ease,box-shadow .3s ease}
.brand-item:hover{transform:translateY(-5px) scale(1.05);box-shadow:0 10px 25px rgba(122,14,33,.15);border-color:var(--granate)}
.brand-item img{max-width:160px;max-height:160px;object-fit:contain;transition:filter .3s ease}
.brand-item:hover img{filter:brightness(1.1)}
@keyframes scroll-brands{0%{transform:translateX(0)}100%{transform:translateX(calc(-100%/2))}}
.brands-btn{position:absolute;top:50%;transform:translateY(-50%);background:var(--granate);color:#fff;border:none;border-radius:999px;width:38px;height:38px;display:none;place-items:center;cursor:pointer;box-shadow:var(--shadow);z-index:1;opacity:.7;transition:opacity .3s ease}
.brands-carousel:hover .brands-btn{display:grid;opacity:1}
.brands-btn:hover{filter:brightness(.95)}
.brands-btn.prev{left:6px}
.brands-btn.next{right:6px}
@media (max-width:700px){.brand-item{width:180px;height:180px}.brand-item img{max-width:140px;max-height:140px}.brands-track{animation-duration:25s}}
@media (max-width:480px){.brand-item{width:150px;height:150px}.brand-item img{max-width:120px;max-height:120px}.brands-btn{width:32px;height:32px}.brands-track{animation-duration:20s}}
.reviews{display:grid;gap:16px;grid-template-columns:repeat(3,1fr)}
.review{background:#fff;border:1px solid rgba(0,0,0,.06);border-radius:12px;padding:16px;display:grid;grid-template-columns:auto 1fr;gap:12px}
.avatar{width:44px;height:44px;border-radius:999px;object-fit:cover;border:1px solid rgba(0,0,0,.06)}
@media (max-width:900px){.reviews{grid-template-columns:1fr}}
@media (max-width:480px){.reviews{gap:12px}.review{padding:12px;gap:10px}.avatar{width:40px;height:40px}}
.about{display:grid;grid-template-columns:.9fr 1.1fr;gap:18px}
.about figure.card{background:transparent;border:none;box-shadow:none}
.skills{display:flex;flex-wrap:wrap;gap:8px}
@media (max-width:900px){.about{grid-template-columns:1fr}}
form{display:grid;gap:12px}
.row-2{display:grid;gap:12px;grid-template-columns:1fr 1fr}
@media (max-width:700px){.row-2{grid-template-columns:1fr}}
@media (max-width:480px){input,select,textarea{padding:14px;font-size:16px}textarea{min-height:100px}.toast{right:8px;bottom:8px;padding:10px 12px;font-size:14px}}
input,select,textarea{width:100%;padding:12px;border-radius:12px;border:1px solid rgba(0,0,0,.12);background:#fff;color:var(--ink);font-family:"DM Serif Text",Georgia,serif}
input:focus,select:focus,textarea:focus{border-color:var(--granate);box-shadow:0 0 0 3px rgba(122,14,33,.12);outline:0}
textarea{min-height:120px;resize:vertical}
.toast{position:fixed;right:16px;bottom:16px;background:#fff;border:1px solid rgba(0,0,0,.1);padding:12px 14px;border-radius:12px;box-shadow:var(--shadow);display:none;z-index:110}
.toast.show{display:block}
.form-msg{margin-top:6px;color:#a00;font-weight:600}
.muted{color:var(--meta)}
.spacer{height:14px}
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}
:focus-visible{outline:2px solid var(--granate);outline-offset:2px;border-radius:10px}
[data-reveal]{opacity:0;transform:translateY(10px);transition:.25s}
[data-reveal].in{opacity:1;transform:none}
.floating{position:fixed;right:18px;bottom:18px;display:none;flex-direction:column;gap:10px;z-index:60}
.floating .circle{border-radius:999px}
.backtop{background:#fff}
@media (min-width:1024px){.floating{display:flex}}
@media (max-width:480px){.floating{right:12px;bottom:12px;gap:8px}.floating .circle{width:44px;height:44px}}
.cookie-banner{position:fixed;left:0;right:0;bottom:0;background:#fff;border-top:1px solid rgba(0,0,0,.1);box-shadow:0 -10px 30px rgba(0,0,0,.06);display:none;z-index:120}
.cookie-banner .text{max-width:760px}
.cookie-banner.show{display:block}
@media (max-width:480px){.cookie-banner{padding:16px}.cookie-banner .text{font-size:14px}}
.consent-row{display:flex;flex-direction:column;gap:6px;margin:10px 0 4px}
.consent{align-self:flex-start;display:flex;gap:8px;align-items:flex-start;color:var(--meta);font-size:14px;line-height:1.4}
.consent input{margin-top:3px}
#herramientas,#servicios.packs-pro,#proceso.process-v4,#contacto{content-visibility:auto;contain-intrinsic-size:1000px 800px}
/* === HERO · FULL (antes en <body>) === */
.hero-full{position:relative;background:url('https://miriamgonzalez.es/Imagenes/FONDO%20DE%20PANTALLA%20GM.png') center/cover no-repeat;min-block-size:100svh;display:grid;place-items:center}
.hero-full::before{content:"";position:absolute;inset:0;background:rgba(247,244,239,.9);z-index:1;pointer-events:none}
.hero-full .wrap{position:relative;z-index:2}
@media (min-width:1001px){.hero-full::before{display:none}.hero-full .wrap{z-index:auto}}
.hero-full .wrap{width:min(1400px,92vw);display:grid;grid-template-columns:1fr 1fr;column-gap:clamp(28px,6vw,96px);row-gap:clamp(18px,3vw,32px);padding-block:clamp(36px,7vh,80px);align-items:stretch;min-block-size:100%}
.hero-full::after{content:"MG";position:absolute;left:max(0px, calc(50% - 760px));top:6%;font:400 clamp(120px,22vw,340px)/1 "Pinyon Script",cursive;color:#7A0E21;opacity:.06;letter-spacing:.02em;pointer-events:none;user-select:none}
.hero-full .identity{max-inline-size:34ch;align-self:center}
.hero-full .eyebrow{color:var(--granate);font-weight:700;letter-spacing:.08em;text-transform:uppercase;font-size:clamp(12px,1.1vw,13px);margin-bottom:.4rem}
.hero-full .who{font:500 clamp(20px,2.4vw,26px)/1.15 "DM Serif Text",Georgia,serif;color:var(--ink);margin:0 0 .2rem}
.hero-full .place{color:var(--meta);font-weight:600;margin:0}
.hero-full .soc{display:flex;gap:12px;margin-top:12px}
.hero-full .soc a{inline-size:42px;block-size:42px;display:grid;place-items:center;border-radius:999px;background:#fff;border:1px solid rgba(0,0,0,.08);color:var(--granate);transition:transform .2s ease}
.hero-full .soc a:hover{transform:translateY(-2px)}
.hero-full .right{align-self:stretch;height:100%;display:flex;flex-direction:column;align-items:flex-end;justify-content:flex-end;gap:6px;max-inline-size:56ch;padding-bottom:clamp(180px,28vh,36vh);margin-left:auto;padding-right:0}
.hero-full h1{margin:0 0 .15rem;color:var(--granate);text-transform:uppercase;letter-spacing:.01em;font-weight:700;line-height:1.06;font-size:clamp(28px,4.5vw,52px);text-align:right}
.hero-full .sub{max-inline-size:48ch;margin:0;text-align:right}
.hero-full .cta-row{display:flex;gap:10px;margin-top:6px;justify-content:flex-end}
@media (max-width:1000px){.hero-full::before{background:rgba(247,244,239,.7)}.hero-full{min-block-size:100svh}.hero-full .wrap{grid-template-columns:1fr;gap:40px;padding-block:60px 40px;align-items:center}}

/* === PORTFOLIO (antes en <style> bajo #portfolio) === */
#portfolio{background:var(--granate);color:#fff;padding:80px 0}
#portfolio h2{color:#fff;margin-bottom:8px}
#portfolio .sub{color:#f2e9ec;margin-bottom:20px}
#portfolio .filters{display:flex;gap:10px;flex-wrap:wrap;margin-bottom:28px}
#portfolio .filters .chip{background:rgba(255,255,255,.15);color:#fff;border:1px solid rgba(255,255,255,.25);padding:.55rem 1rem;border-radius:999px;font-weight:600;cursor:pointer;transition:.2s}
#portfolio .filters .chip[data-active="true"]{background:#fff;color:var(--granate)}
@media (max-width:480px){#portfolio .filters{gap:8px;margin-bottom:20px}#portfolio .filters .chip{padding:.45rem .8rem;font-size:14px}}
#portfolio .grid{display:grid;gap:20px}
@media(min-width:1100px){#portfolio .grid{grid-template-columns:repeat(3,1fr)}}
@media(max-width:1099px){#portfolio .grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:700px){#portfolio .grid{grid-template-columns:1fr}}
#portfolio .card{background:#fff;color:#000;border-radius:14px;overflow:hidden;box-shadow:0 8px 24px rgba(0,0,0,.25);transition:.25s transform}
#portfolio .card:hover{transform:translateY(-6px)}
.video-wrap{position:relative;aspect-ratio:9/16;background:#000;cursor:pointer}
.video-wrap video{width:100%;height:100%;object-fit:cover;display:block;background:#000;transition:opacity .3s ease}
.video-wrap video[poster]{background-size:cover;background-position:center;background-repeat:no-repeat}
.video-wrap .play-btn{position:absolute;inset:0;margin:auto;width:64px;height:64px;border-radius:50%;background:rgba(255,255,255,.95);display:grid;place-items:center;box-shadow:0 8px 20px rgba(0,0,0,.35);transition:.2s;pointer-events:none;z-index:2}
.video-wrap .play-btn::before{content:"";border-style:solid;border-width:12px 0 12px 20px;border-color:transparent transparent transparent var(--granate);margin-left:4px}
.video-wrap.playing .play-btn{display:none}
.video-wrap:hover .play-btn{transform:scale(1.1);background:rgba(255,255,255,1)}
.video-wrap.loading::after{content:"";position:absolute;top:50%;left:50%;width:32px;height:32px;margin:-16px 0 0 -16px;border:3px solid rgba(255,255,255,0.3);border-top:3px solid var(--granate);border-radius:50%;animation:spin 1s linear infinite;z-index:1}
@keyframes spin{0%{transform:rotate(0deg)}100%{transform:rotate(360deg)}}
#portfolio .card .meta,#portfolio .video-wrap .thumb{display:none!important}
#portfolio .more-wrap{display:flex;justify-content:center;margin-top:22px}
@media(max-width:700px){#portfolio .grid{grid-template-columns:1fr;gap:24px;padding:0 8px}#portfolio .card{margin:0 auto;max-width:380px;border-radius:16px}.video-wrap{cursor:pointer;position:relative}.video-wrap .play-btn{width:80px;height:80px;background:rgba(255,255,255,.98);box-shadow:0 12px 32px rgba(0,0,0,.4);border:3px solid rgba(122,14,33,.1)}.video-wrap .play-btn::before{border-width:16px 0 16px 24px;margin-left:6px}#portfolio .card:hover{transform:none}.video-wrap::after{content:"";position:absolute;top:50%;left:50%;width:120px;height:120px;transform:translate(-50%,-50%);border-radius:50%;background:transparent;z-index:3;pointer-events:auto}.video-wrap.touched{transform:scale(.98);transition:transform .1s ease}.video-wrap.loading .play-btn{background:rgba(255,255,255,.8)}.video-wrap.loading::before{content:"";position:absolute;top:50%;left:50%;width:40px;height:40px;margin:-20px 0 0 -20px;border:4px solid rgba(255,255,255,0.3);border-top:4px solid var(--granate);border-radius:50%;animation:spin 1s linear infinite;z-index:4}}
@media(max-width:480px){#portfolio .grid{gap:20px;padding:0 4px}#portfolio .card{max-width:340px;border-radius:12px}#portfolio .filters{gap:6px;margin-bottom:16px;justify-content:center}#portfolio .filters .chip{padding:.4rem .7rem;font-size:13px;min-height:36px}.video-wrap .play-btn{width:72px;height:72px}.video-wrap .play-btn::before{border-width:14px 0 14px 20px;margin-left:5px}}

/* === SERVICIOS · PACKS PRO === */
#servicios.packs-pro{position:relative;background:var(--bone);padding:96px 0 80px;isolation:isolate}
#servicios.packs-pro::before,#servicios.packs-pro::after{content:"";position:absolute;inset:auto -10% -25% -10%;height:70%;background:radial-gradient(60% 60% at 15% 10%, rgba(122,14,33,.10), transparent 60%),radial-gradient(50% 50% at 85% 90%, rgba(122,14,33,.08), transparent 60%);z-index:-1;pointer-events:none}
#servicios.packs-pro h2{text-align:center;margin:0 0 10px;font-family:"DM Serif Text",Georgia,serif;font-size:clamp(28px,4vw,42px);font-weight:500}
#servicios.packs-pro .sub{text-align:center;color:var(--meta);margin:0 0 28px}
.packs-grid{display:grid;gap:22px;grid-template-columns:repeat(3,minmax(260px,1fr))}
@media (max-width:1000px){.packs-grid{grid-template-columns:repeat(2,1fr)}}
@media (max-width:680px){.packs-grid{grid-template-columns:1fr}}
.pack{position:relative;border-radius:20px;background:#fff;overflow:hidden;padding:24px 22px 20px;border:1px solid rgba(0,0,0,.06);box-shadow:0 14px 42px rgba(0,0,0,.10);transition:transform .2s ease,box-shadow .2s ease}
.pack::before{content:"";position:absolute;inset:-1px;border-radius:inherit;padding:1.2px;background:linear-gradient(135deg,#7A0E21,#cc6b7b 40%,#7A0E21 80%);mask:linear-gradient(#000 0 0) content-box,linear-gradient(#000 0 0);-webkit-mask:linear-gradient(#000 0 0) content-box,linear-gradient(#000 0 0);-webkit-mask-composite:xor;mask-composite:exclude;pointer-events:none;opacity:.8}
.pack:hover{transform:translateY(-6px);box-shadow:0 22px 56px rgba(0,0,0,.14)}
.pack--featured{background:linear-gradient(180deg,#ffffff,#fff5f6)}
.pack .badge{position:absolute;top:12px;right:12px;background:var(--granate);color:#fff;border-radius:999px;padding:.35rem .65rem;font-weight:700;font-size:12px}
.pack .head{display:flex;align-items:center;gap:10px;margin-bottom:10px}
.pack .icon{width:38px;height:38px;border-radius:12px;display:grid;place-items:center;color:#fff;background:var(--granate);flex:0 0 auto}
.pack h3{margin:0;font-size:1.15rem;color:var(--granate)}
.pack .hint{margin:0;color:var(--meta);font-size:.92rem}
.pack .features{list-style:none;margin:10px 0 14px;padding:0}
.pack .features li{display:flex;gap:10px;align-items:flex-start;margin:.5rem 0}
.pack .features .chk{width:18px;height:18px;flex:0 0 auto;border-radius:6px;background:rgba(122,14,33,.12);display:grid;place-items:center;color:var(--granate)}
.pack .foot{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-top:8px}
.pack .eta{color:var(--meta);font-weight:600;font-size:.9rem}
.pack .btn{padding:.75rem 1rem;border-radius:12px;border:1px solid rgba(0,0,0,.08);font-weight:700}
.pack .btn-primary{background:var(--granate);color:#fff;border:none}
.pack .btn-primary:hover{filter:brightness(.95)}
.extras-wrap{margin-top:34px}
.extras-wrap h3{text-align:center;margin:0 0 12px;font-family:"Pinyon Script",cursive;font-size:clamp(24px,3vw,32px);font-weight:400}
.extras{display:flex;flex-wrap:wrap;gap:10px;justify-content:center}
.extras .chip{display:inline-flex;align-items:center;gap:8px;padding:.6rem .9rem;border-radius:999px;background:#fff;border:1px solid rgba(0,0,0,.12);font-weight:700;color:var(--granate)}
.extras .chip svg{width:16px;height:16px}

/* === SOBRE MÍ === */
#sobre-mi{background:var(--bone);padding:80px 0}
/* 3 columnas proporcionales: FOTO | FOTO | TEXTO */
#sobre-mi .about-3col{display:grid;grid-template-columns:minmax(280px,1.2fr) minmax(280px,1.2fr) minmax(340px,1fr);row-gap:28px;column-gap:14px;align-items:center;width:min(1200px,92vw);margin:0 auto}
/* Tarjetas de foto compactas */
#sobre-mi .ph{aspect-ratio:4/5;position:relative;overflow:hidden;border-radius:16px;background:#fff;border:1px solid rgba(0,0,0,.06);box-shadow:0 6px 18px rgba(0,0,0,.08)}
#sobre-mi .ph img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .35s ease}
#sobre-mi .ph:hover img{transform:scale(1.035)}
#sobre-mi .ph--shift{margin-top:8px}
#sobre-mi .ph::after{content:"";position:absolute;inset:0;border-radius:16px;pointer-events:none;box-shadow:inset 0 0 0 6px rgba(255,255,255,.6), inset 0 0 0 1px rgba(0,0,0,.05)}
/* Texto y chips */
#sobre-mi article h2{margin:0 0 10px}
#sobre-mi article p{margin:0 0 14px;color:var(--ink)}
/* Responsive */
@media (max-width:980px){#sobre-mi .about-3col{grid-template-columns:1fr 1fr}#sobre-mi article{grid-column:1 / -1;text-align:center}}
@media (max-width:640px){#sobre-mi .about-3col{grid-template-columns:1fr}#sobre-mi .ph--shift{margin-top:0}}
@media (max-width:480px){#sobre-mi{padding:60px 0}#sobre-mi .about-3col{gap:16px}#sobre-mi article{padding:0 8px}#sobre-mi article h2{font-size:clamp(20px,4vw,24px)}#sobre-mi article p{font-size:15px;line-height:1.5}}
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}
:focus-visible{outline:2px solid var(--granate);outline-offset:2px;border-radius:10px}
[data-reveal]{opacity:0;transform:translateY(10px);transition:.25s}
[data-reveal].in{opacity:1;transform:none}
.floating{position:fixed;right:18px;bottom:18px;display:none;flex-direction:column;gap:10px;z-index:60}
.floating .circle{border-radius:999px}
.backtop{background:#fff}
@media (min-width:1024px){.floating{display:flex}}
@media (max-width:480px){.floating{right:12px;bottom:12px;gap:8px}.floating .circle{width:44px;height:44px}}
.cookie-banner{position:fixed;left:0;right:0;bottom:0;background:#fff;border-top:1px solid rgba(0,0,0,.1);box-shadow:0 -10px 30px rgba(0,0,0,.06);display:none;z-index:120}
.cookie-banner .text{max-width:760px}
.cookie-banner.show{display:block}
@media (max-width:480px){.cookie-banner{padding:16px}.cookie-banner .text{font-size:14px}}
.consent-row{display:flex;flex-direction:column;gap:6px;margin:10px 0 4px}
.consent{align-self:flex-start;display:flex;gap:8px;align-items:flex-start;color:var(--meta);font-size:14px;line-height:1.4}
.consent input{margin-top:3px}
#herramientas,#servicios.packs-pro,#proceso.process-v4,#contacto{content-visibility:auto;contain-intrinsic-size:1000px 800px}
/* === HERO · FULL (antes en <body>) === */
.hero-full{position:relative;background:url('https://miriamgonzalez.es/Imagenes/FONDO%20DE%20PANTALLA%20GM.png') center/cover no-repeat;min-block-size:100svh;display:grid;place-items:center}
.hero-full::before{content:"";position:absolute;inset:0;background:rgba(247,244,239,.9);z-index:1;pointer-events:none}
.hero-full .wrap{position:relative;z-index:2}
@media (min-width:1001px){.hero-full::before{display:none}.hero-full .wrap{z-index:auto}}
.hero-full .wrap{width:min(1400px,92vw);display:grid;grid-template-columns:1fr 1fr;column-gap:clamp(28px,6vw,96px);row-gap:clamp(18px,3vw,32px);padding-block:clamp(36px,7vh,80px);align-items:stretch;min-block-size:100%}
.hero-full::after{content:"MG";position:absolute;left:max(0px, calc(50% - 760px));top:6%;font:400 clamp(120px,22vw,340px)/1 "Pinyon Script",cursive;color:#7A0E21;opacity:.06;letter-spacing:.02em;pointer-events:none;user-select:none}
.hero-full .identity{max-inline-size:34ch;align-self:center}
.hero-full .eyebrow{color:var(--granate);font-weight:700;letter-spacing:.08em;text-transform:uppercase;font-size:clamp(12px,1.1vw,13px);margin-bottom:.4rem}
.hero-full .who{font:500 clamp(20px,2.4vw,26px)/1.15 "DM Serif Text",Georgia,serif;color:var(--ink);margin:0 0 .2rem}
.hero-full .place{color:var(--meta);font-weight:600;margin:0}
.hero-full .soc{display:flex;gap:12px;margin-top:12px}
.hero-full .soc a{inline-size:42px;block-size:42px;display:grid;place-items:center;border-radius:999px;background:#fff;border:1px solid rgba(0,0,0,.08);color:var(--granate);transition:transform .2s ease}
.hero-full .soc a:hover{transform:translateY(-2px)}
.hero-full .right{align-self:stretch;height:100%;display:flex;flex-direction:column;align-items:flex-end;justify-content:flex-end;gap:6px;max-inline-size:56ch;padding-bottom:clamp(180px,28vh,36vh);margin-left:auto;padding-right:0}
.hero-full h1{margin:0 0 .15rem;color:var(--granate);text-transform:uppercase;letter-spacing:.01em;font-weight:700;line-height:1.06;font-size:clamp(28px,4.5vw,52px);text-align:right}
.hero-full .sub{max-inline-size:48ch;margin:0;text-align:right}
.hero-full .cta-row{display:flex;gap:10px;margin-top:6px;justify-content:flex-end}
@media (max-width:1000px){.hero-full::before{background:rgba(247,244,239,.7)}.hero-full{min-block-size:100svh}.hero-full .wrap{grid-template-columns:1fr;gap:40px;padding-block:60px 40px;align-items:center}}

/* === PORTFOLIO (antes en <style> bajo #portfolio) === */
#portfolio{background:var(--granate);color:#fff;padding:80px 0}
#portfolio h2{color:#fff;margin-bottom:8px}
#portfolio .sub{color:#f2e9ec;margin-bottom:20px}
#portfolio .filters{display:flex;gap:10px;flex-wrap:wrap;margin-bottom:28px}
#portfolio .filters .chip{background:rgba(255,255,255,.15);color:#fff;border:1px solid rgba(255,255,255,.25);padding:.55rem 1rem;border-radius:999px;font-weight:600;cursor:pointer;transition:.2s}
#portfolio .filters .chip[data-active="true"]{background:#fff;color:var(--granate)}
@media (max-width:480px){#portfolio .filters{gap:8px;margin-bottom:20px}#portfolio .filters .chip{padding:.45rem .8rem;font-size:14px}}
#portfolio .grid{display:grid;gap:20px}
@media(min-width:1100px){#portfolio .grid{grid-template-columns:repeat(3,1fr)}}
@media(max-width:1099px){#portfolio .grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:700px){#portfolio .grid{grid-template-columns:1fr}}
#portfolio .card{background:#fff;color:#000;border-radius:14px;overflow:hidden;box-shadow:0 8px 24px rgba(0,0,0,.25);transition:.25s transform}
#portfolio .card:hover{transform:translateY(-6px)}
.video-wrap{position:relative;aspect-ratio:9/16;background:#000;cursor:pointer}
.video-wrap video{width:100%;height:100%;object-fit:cover;display:block;background:#000;transition:opacity .3s ease}
.video-wrap video[poster]{background-size:cover;background-position:center;background-repeat:no-repeat}
.video-wrap .play-btn{position:absolute;inset:0;margin:auto;width:64px;height:64px;border-radius:50%;background:rgba(255,255,255,.95);display:grid;place-items:center;box-shadow:0 8px 20px rgba(0,0,0,.35);transition:.2s;pointer-events:none;z-index:2}
.video-wrap .play-btn::before{content:"";border-style:solid;border-width:12px 0 12px 20px;border-color:transparent transparent transparent var(--granate);margin-left:4px}
.video-wrap.playing .play-btn{display:none}
.video-wrap:hover .play-btn{transform:scale(1.1);background:rgba(255,255,255,1)}
.video-wrap.loading::after{content:"";position:absolute;top:50%;left:50%;width:32px;height:32px;margin:-16px 0 0 -16px;border:3px solid rgba(255,255,255,0.3);border-top:3px solid var(--granate);border-radius:50%;animation:spin 1s linear infinite;z-index:1}
@keyframes spin{0%{transform:rotate(0deg)}100%{transform:rotate(360deg)}}
#portfolio .card .meta,#portfolio .video-wrap .thumb{display:none!important}
#portfolio .more-wrap{display:flex;justify-content:center;margin-top:22px}
@media(max-width:700px){#portfolio .grid{grid-template-columns:1fr;gap:24px;padding:0 8px}#portfolio .card{margin:0 auto;max-width:380px;border-radius:16px}.video-wrap{cursor:pointer;position:relative}.video-wrap .play-btn{width:80px;height:80px;background:rgba(255,255,255,.98);box-shadow:0 12px 32px rgba(0,0,0,.4);border:3px solid rgba(122,14,33,.1)}.video-wrap .play-btn::before{border-width:16px 0 16px 24px;margin-left:6px}#portfolio .card:hover{transform:none}.video-wrap::after{content:"";position:absolute;top:50%;left:50%;width:120px;height:120px;transform:translate(-50%,-50%);border-radius:50%;background:transparent;z-index:3;pointer-events:auto}.video-wrap.touched{transform:scale(.98);transition:transform .1s ease}.video-wrap.loading .play-btn{background:rgba(255,255,255,.8)}.video-wrap.loading::before{content:"";position:absolute;top:50%;left:50%;width:40px;height:40px;margin:-20px 0 0 -20px;border:4px solid rgba(255,255,255,0.3);border-top:4px solid var(--granate);border-radius:50%;animation:spin 1s linear infinite;z-index:4}}
@media(max-width:480px){#portfolio .grid{gap:20px;padding:0 4px}#portfolio .card{max-width:340px;border-radius:12px}#portfolio .filters{gap:6px;margin-bottom:16px;justify-content:center}#portfolio .filters .chip{padding:.4rem .7rem;font-size:13px;min-height:36px}.video-wrap .play-btn{width:72px;height:72px}.video-wrap .play-btn::before{border-width:14px 0 14px 20px;margin-left:5px}}

/* === SERVICIOS · PACKS PRO === */
#servicios.packs-pro{position:relative;background:var(--bone);padding:96px 0 80px;isolation:isolate}
#servicios.packs-pro::before,#servicios.packs-pro::after{content:"";position:absolute;inset:auto -10% -25% -10%;height:70%;background:radial-gradient(60% 60% at 15% 10%, rgba(122,14,33,.10), transparent 60%),radial-gradient(50% 50% at 85% 90%, rgba(122,14,33,.08), transparent 60%);z-index:-1;pointer-events:none}
#servicios.packs-pro h2{text-align:center;margin:0 0 10px;font-family:"DM Serif Text",Georgia,serif;font-size:clamp(28px,4vw,42px);font-weight:500}
#servicios.packs-pro .sub{text-align:center;color:var(--meta);margin:0 0 28px}
.packs-grid{display:grid;gap:22px;grid-template-columns:repeat(3,minmax(260px,1fr))}
@media (max-width:1000px){.packs-grid{grid-template-columns:repeat(2,1fr)}}
@media (max-width:680px){.packs-grid{grid-template-columns:1fr}}
.pack{position:relative;border-radius:20px;background:#fff;overflow:hidden;padding:24px 22px 20px;border:1px solid rgba(0,0,0,.06);box-shadow:0 14px 42px rgba(0,0,0,.10);transition:transform .2s ease,box-shadow .2s ease}
.pack::before{content:"";position:absolute;inset:-1px;border-radius:inherit;padding:1.2px;background:linear-gradient(135deg,#7A0E21,#cc6b7b);}
.pack:hover{transform:translateY(-6px);box-shadow:0 22px 56px rgba(0,0,0,.14)}
.pack--featured{background:linear-gradient(180deg,#ffffff,#fff5f6)}
.pack .badge{position:absolute;top:12px;right:12px;background:var(--granate);color:#fff;border-radius:999px;padding:.35rem .65rem;font-weight:700;font-size:12px}
.pack .head{display:flex;align-items:center;gap:10px;margin-bottom:10px}
.pack .icon{width:38px;height:38px;border-radius:12px;display:grid;place-items:center;color:#fff;background:var(--granate);flex:0 0 auto}
.pack h3{margin:0;font-size:1.15rem;color:var(--granate)}
.pack .hint{margin:0;color:var(--meta);font-size:.92rem}
.pack .features{list-style:none;margin:10px 0 14px;padding:0}
.pack .features li{display:flex;gap:10px;align-items:flex-start;margin:.5rem 0}
.pack .features .chk{width:18px;height:18px;flex:0 0 auto;border-radius:6px;background:rgba(122,14,33,.12);display:grid;place-items:center;color:var(--granate)}
.pack .foot{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-top:8px}
.pack .eta{color:var(--meta);font-weight:600;font-size:.9rem}
.pack .btn{padding:.75rem 1rem;border-radius:12px;border:1px solid rgba(0,0,0,.08);font-weight:700}
.pack .btn-primary{background:var(--granate);color:#fff;border:none}
.pack .btn-primary:hover{filter:brightness(.95)}
.extras-wrap{margin-top:34px}
.extras-wrap h3{text-align:center;margin:0 0 12px;font-family:"Pinyon Script",cursive;font-size:clamp(24px,3vw,32px);font-weight:400}
.extras{display:flex;flex-wrap:wrap;gap:10px;justify-content:center}
.extras .chip{display:inline-flex;align-items:center;gap:8px;padding:.6rem .9rem;border-radius:999px;background:#fff;border:1px solid rgba(0,0,0,.12);font-weight:700;color:var(--granate)}
.extras .chip svg{width:16px;height:16px}

/* === HERRAMIENTAS · PÓSTER === */
.sr-only{position:absolute!important;width:1px;height:1px;margin:-1px;overflow:hidden;clip:rect(0,0,0,0)}
#herramientas.tools-poster{background:#7A0E21;padding:0}
#herramientas.tools-poster .wrap{max-width:min(1400px,96vw);margin:0 auto}
#herramientas.tools-poster img{display:block;width:100%;height:auto}

/* === RESEÑAS v1 === */
#resenas.reviews-v1{background:linear-gradient(135deg,#f8f9fa 0%,#ffffff 100%);padding:clamp(55px,9vw,90px) 0;position:relative;overflow:hidden}
#resenas.reviews-v1::before{content:"";position:absolute;inset:0;background:radial-gradient(circle at 15% 25%, rgba(122,14,33,0.03) 0%, transparent 40%),radial-gradient(circle at 85% 75%, rgba(122,14,33,0.02) 0%, transparent 40%);pointer-events:none}
#resenas .container{width:min(1150px,91vw);margin:0 auto;position:relative;z-index:1}
#resenas .eyebrow{text-align:center;margin:0 0 4px;color:var(--granate);font-family:"Pinyon Script",cursive;font-weight:400;font-size:clamp(19px,3.2vw,26px)}
#resenas h2{text-align:center;margin:0 0 clamp(14px,1vw,22px);font-family:"DM Serif Text",Georgia,serif;font-weight:500;font-size:clamp(26px,4.8vw,39px);color:var(--ink)}
#resenas h2::after{margin:11px auto 0;width:55px;height:3.5px}
#resenas{background:linear-gradient(135deg,#f8f9fa 0%,#ffffff 100%);padding:clamp(16px,3.5vw,28px) 0}
#resenas .container{width:min(1150px,92vw);margin:0 auto}
#resenas .reviews-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:14px;max-width:950px;margin:0 auto}
@media (max-width:900px){#resenas .reviews-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}
@media (max-width:540px){#resenas .reviews-grid{grid-template-columns:1fr}}
#resenas .reviews-grid img{width:100%;height:auto;aspect-ratio:1/1;object-fit:contain;object-position:center;display:block;border-radius:14px;background:#fff;border:1px solid rgba(122,14,33,.12);box-shadow:0 8px 24px rgba(0,0,0,.08),0 2px 6px rgba(0,0,0,.04);transition:transform .25s ease, box-shadow .25s ease, border-color .25s ease;animation:resenaIn .45s ease both;padding:4px 3px 4px 8px}
#resenas .reviews-grid img:hover{transform:translateY(-4px);box-shadow:0 14px 36px rgba(0,0,0,.12),0 6px 14px rgba(0,0,0,.06);border-color:rgba(122,14,33,.18)}
@keyframes resenaIn{from{opacity:.0;transform:translateY(22px)}to{opacity:1;transform:translateY(0)}}
/* ... resto de estilos de reseñas se encuentran en index.html si aplica ... */

/* === PROCESO v4 === */
#proceso.process-v4{padding:84px 0;background:var(--bone);color:var(--ink);position:relative}
#proceso.process-v4 .p4-head{text-align:center;margin-bottom:32px}
#proceso.process-v4 h2{font-family:"DM Serif Text",Georgia,serif;margin:0 0 8px;font-weight:500}
#proceso.process-v4 .sub{color:var(--meta);margin:0}
#proceso.process-v4 .p4-grid{display:grid;gap:18px;grid-template-columns:repeat(4,1fr);width:min(1200px,92vw);margin:0 auto}
@media (max-width:1100px){#proceso.process-v4 .p4-grid{grid-template-columns:repeat(3,1fr)}}
@media (max-width:840px){#proceso.process-v4 .p4-grid{grid-template-columns:repeat(2,1fr)}}
@media (max-width:560px){#proceso.process-v4 .p4-grid{grid-template-columns:1fr}}
@media (max-width:480px){#proceso.process-v4{padding:60px 0}#proceso.process-v4 .p4-card{padding:16px 14px}#proceso.process-v4 .p4-title{font-size:1rem;gap:8px}#proceso.process-v4 .p4-n{width:24px;height:24px;font-size:14px}}
#proceso.process-v4 .p4-card{position:relative;background:#fff;border:1px solid rgba(0,0,0,.06);border-radius:16px;padding:18px 16px;box-shadow:0 8px 24px rgba(0,0,0,.06);transition:transform .18s ease,box-shadow .18s ease,border-color .18s ease}
#proceso.process-v4 .p4-card:hover{transform:translateY(-3px);box-shadow:0 14px 36px rgba(0,0,0,.10)}
#proceso.process-v4 .p4-card::before{content:"";position:absolute;left:0;right:0;top:0;height:3px;background:linear-gradient(90deg,var(--granate),var(--granate-2))}
#proceso.process-v4 .p4-title{margin:0 0 8px;display:flex;align-items:center;gap:10px;line-height:1.2;color:var(--granate);font-weight:700;font-size:1.06rem}
#proceso.process-v4 .p4-n{display:inline-grid;place-items:center;width:28px;height:28px;border-radius:999px;background:rgba(122,14,33,.10);color:var(--granate);font-weight:800;font-variant-numeric:tabular-nums;border:1px solid rgba(0,0,0,.06)}
#proceso.process-v4 .p4-list{margin:0;padding-left:1.05rem}
#proceso.process-v4 .p4-list li{margin:.3rem 0}
#proceso.process-v4 .p4-list li::marker{color:var(--granate)}
#proceso.process-v4 [data-reveal]{opacity:0;transform:translateY(10px);transition:.25s}
#proceso.process-v4 [data-reveal].in{opacity:1;transform:none}
@media (prefers-reduced-motion:reduce){#proceso.process-v4 .p4-card,#proceso.process-v4 [data-reveal]{transition:none !important}}

/* === CONTACTO === */
#contacto .contact-card {
  position: relative; overflow: hidden;
  background: #fff; border: 1px solid rgba(0,0,0,.06);
  border-radius: 18px; box-shadow: var(--shadow); padding: 20px;
  background:
    radial-gradient(140% 90% at -10% -10%, #7a0e210f 0%, transparent 60%),
    radial-gradient(120% 80% at 110% 110%, #7a0e2112 0%, transparent 60%),
    #fff;
}
#contacto .contact-card::before {
  content: ""; position: absolute; inset: 0 0 auto 0; height: 6px;
  background: linear-gradient(90deg, var(--granate), var(--granate-2));
}

#contacto .card-head {
  display: flex; align-items: flex-start; justify-content: space-between; gap: 14px; flex-wrap: wrap; margin-bottom: 10px;
}
#contacto .card-head h3 { margin: .1rem 0; font-family: "DM Serif Text", Georgia, serif; font-weight: 500; }
#contacto .lead { color: var(--meta); max-width: 56ch; margin: 0 }
#contacto .quick { display: flex; gap: 8px; flex-wrap: wrap; margin: .4rem 0 0 }
#contacto .quick .btn { padding: .6rem .8rem }

/* ====== CAMPOS ====== */
#contacto form { display: grid; gap: 12px; margin-top: 14px }
#contacto .form-grid { display: grid; gap: 12px; grid-template-columns: 1fr 1fr }
@media (max-width: 760px) {
  #contacto .form-grid { grid-template-columns: 1fr }
  #contacto .contact-card { margin: 0 4px }
  #contacto .form-actions { flex-wrap: wrap; gap: 8px }
}
@media (max-width: 480px) {
  #contacto { padding: 40px 0 }
  #contacto .contact-card { padding: 16px; margin: 0 8px }
  #contacto .card-head { flex-direction: column; align-items: flex-start; gap: 10px }
  #contacto .quick { justify-content: center; flex-wrap: wrap }
  #contacto .quick .btn { padding: .7rem 1rem; font-size: 15px; min-width: 120px }
  #contacto input:not([type="checkbox"]):not([type="radio"]),
  #contacto select, #contacto textarea { padding: 14px; font-size: 16px }
  #contacto textarea { min-height: 100px }
  #contacto .form-actions { flex-direction: column; gap: 8px }
  #contacto .form-actions .btn { width: 100%; justify-content: center }
  #contacto .segmented { justify-content: center }
  #contacto .segmented label { padding: .6rem 1rem; font-size: 14px }
}

#contacto input:not([type="checkbox"]):not([type="radio"]),
#contacto select, #contacto textarea {
  width: 100%; padding: 12px; border-radius: 12px; border: 1px solid rgba(0,0,0,.12);
  background: #fff; color: var(--ink); font: inherit;
}
#contacto input::placeholder, #contacto textarea::placeholder { color: #777 }
#contacto input:focus, #contacto select:focus, #contacto textarea:focus {
  border-color: var(--granate); box-shadow: 0 0 0 3px rgba(122,14,33,.12); outline: 0;
}
#contacto textarea { min-height: 120px; resize: vertical }

/* Presupuesto (radios segmentados) */
#contacto .segmented { display: flex; gap: 8px; flex-wrap: wrap }
#contacto .segmented input { position: absolute; opacity: 0; pointer-events: none }
#contacto .segmented label {
  padding: .55rem .8rem; border-radius: 999px; border: 1px solid rgba(0,0,0,.12);
  background: #fff; cursor: pointer; font-weight: 600; font-size: 14px; transition: .2s;
}
#contacto .segmented label:hover { transform: translateY(-1px); border-color: var(--granate) }
#contacto .segmented input:checked + label { background: var(--granate); color: #fff; border-color: var(--granate) }

/* ====== CONSENTIMIENTO MEJORADO ====== */
#contacto .policy-badges { display: flex; gap: 6px; flex-wrap: wrap; margin-top: 2px }
#contacto .policy-badges .pill {
  display: inline-flex; align-items: center; gap: 6px;
  padding: .25rem .55rem; border-radius: 999px; font-weight: 600; font-size: 12px;
  background: #fff; border: 1px solid rgba(0,0,0,.08); color: var(--granate);
}

#contacto .consent-wrap { display: flex; flex-direction: column; gap: 8px }
#contacto .consent-card {
  display: flex; gap: 10px; align-items: flex-start;
  padding: 12px; border-radius: 14px;
  border: 1px solid rgba(0,0,0,.12); background: linear-gradient(0deg,#fff, #fff);
  transition: .2s border-color, .2s box-shadow, .2s background;
}
#contacto .consent-card:hover { border-color: rgba(122,14,33,.35) }
#contacto .consent-card[data-error="1"] { border-color: #a00; box-shadow: 0 0 0 3px rgba(170,0,0,.1) }

/* Checkbox grande y con color de acento */
#contacto .consent-card input[type="checkbox"] {
  width: 20px; height: 20px; margin-top: 2px; flex: 0 0 auto; accent-color: var(--granate);
}
#contacto .consent-title { font-weight: 500; font-family: "DM Serif Text", Georgia, serif; }
#contacto .consent-text { color: var(--meta); font-size: 14px; line-height: 1.45 }
#contacto .consent-link { font-weight: 500; color: var(--granate); text-decoration: underline; font-family: "DM Serif Text", Georgia, serif; }
#contacto .consent-status {
  margin-left: auto; align-self: center; font-size: 12px; font-weight: 500;
  padding: .2rem .5rem; border-radius: 999px; border: 1px solid rgba(0,0,0,.08); background: #fff; color: #1a7f50; display: none;
  font-family: "DM Serif Text", Georgia, serif;
}
/* Mostrar “Aceptado” cuando está checkeado */
#contacto .consent-card input[type="checkbox"]:checked ~ .consent-status { display: inline-block }

/* Acciones y mensajes */
#contacto .form-actions { display: flex; gap: 10px; flex-wrap: wrap; margin-top: 2px }
#contacto .help { color: var(--meta); font-size: 13px }
#contacto .form-msg { margin-top: 4px; font-weight: 600 }
#contacto .btn-loading { display: none }
#contacto .is-loading .btn-text { display: none }
#contacto .is-loading .btn-loading { display: inline }

/* === RESEÑAS v1 · ajustes adicionales === */
#resenas [data-reveal]{opacity:0;transform:translateY(25px);transition:all .55s cubic-bezier(0.4,0,0.2,1)}
#resenas [data-reveal].in{opacity:1;transform:translateY(0)}
#resenas [data-reveal]:nth-child(1){transition-delay:.08s}
#resenas [data-reveal]:nth-child(2){transition-delay:.15s}
#resenas [data-reveal]:nth-child(3){transition-delay:.22s}
@media (max-width:768px) and (min-width:481px){#resenas .r{height:clamp(180px,22vw,220px)}#resenas .r img{padding:clamp(11px,2.5vw,16px)}#resenas .g{gap:clamp(15px,3vw,22px);max-width:650px}}
@media (max-width:480px){#resenas .r{border-radius:11px;height:260px}#resenas .r img{padding:11px}#resenas{padding:45px 0}}
#resenas .r:focus-visible{outline:2.5px solid var(--granate);outline-offset:3.5px}
@media (prefers-reduced-motion:reduce){#resenas .r,#resenas [data-reveal],#resenas .r img{transition:none !important}#resenas .r:hover{transform:none}#resenas .r:hover img{transform:none}}

/* INJECT */