*{margin:0;padding:0;box-sizing:border-box}
:root{
--sand:#e8ddd3;--clay:#b5896e;--terracotta:#c4704b;--espresso:#2e1f14;
--cream:#f5f0eb;--warm-white:#faf8f5;--sage:#8a9a7b;--gold:#c9a84c;
}
html{scroll-behavior:smooth}
body{font-family:'DM Sans',sans-serif;color:var(--espresso);background:var(--warm-white);overflow-x:hidden}

/* ACCESSIBILITY */
:focus-visible{outline:2px solid var(--terracotta);outline-offset:2px}
.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}
.skip-link{position:absolute;top:-100%;left:50%;transform:translateX(-50%);background:var(--espresso);color:var(--cream);padding:.75rem 1.5rem;border-radius:0 0 8px 8px;z-index:9999;transition:top .2s}
.skip-link:focus{top:0}

/* HERO */
.hero{min-height:100vh;display:flex;flex-direction:column;justify-content:center;align-items:center;text-align:center;padding:2rem;position:relative;background:linear-gradient(165deg,#faf8f5 0%,#f0e8e0 40%,#ddd0c4 100%);overflow:hidden}
.hero::before{content:'';position:absolute;inset:0;background:url("data:image/svg+xml,%3Csvg width='60' height='60' viewBox='0 0 60 60' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='none' fill-rule='evenodd'%3E%3Cg fill='%232e1f14' fill-opacity='0.03'%3E%3Cpath d='M36 34v-4h-2v4h-4v2h4v4h2v-4h4v-2h-4zm0-30V0h-2v4h-4v2h4v4h2V6h4V4h-4zM6 34v-4H4v4H0v2h4v4h2v-4h4v-2H6zM6 4V0H4v4H0v2h4v4h2V6h4V4H6z'/%3E%3C/g%3E%3C/g%3E%3C/svg%3E")}
.hero-badge{display:inline-block;padding:.4rem 1.2rem;border:1px solid var(--espresso);border-radius:50px;font-size:.75rem;letter-spacing:3px;text-transform:uppercase;margin-bottom:2rem;opacity:0;animation:fadeUp .8s .3s forwards}






.hero h1 span{color:var(--terracotta);font-style:italic}
.hero-sub{font-size:clamp(1rem,2.5vw,1.35rem);font-weight:300;max-width:540px;line-height:1.6;margin-top:1rem;opacity:0;animation:fadeUp .8s .7s forwards}
.hero-cta{margin-top:2.5rem;display:flex;gap:1rem;flex-wrap:wrap;justify-content:center;opacity:0;animation:fadeUp .8s .9s forwards}
.btn{padding:.9rem 2.2rem;border-radius:50px;text-decoration:none;font-size:.9rem;font-weight:500;letter-spacing:1px;transition:all .3s}
.btn-primary{background:#63564b;color:var(--cream);border:2px solid #63564b}
.btn-primary:hover{background:#7a6b5e;border-color:#7a6b5e;color:var(--cream)}
.contact .btn-primary{background:var(--clay);border-color:var(--clay)}
.contact .btn-primary:hover{background:var(--terracotta);border-color:var(--terracotta)}
.btn-outline{border:2px solid #63564b;color:#63564b}
.btn-outline:hover{background:#63564b;color:var(--cream)}
.scroll-hint{position:absolute;bottom:2rem;opacity:0;animation:fadeUp .8s 1.2s forwards}
.scroll-hint span{display:block;width:1px;height:40px;background:var(--espresso);margin:0 auto;animation:scrollPulse 2s infinite}

/* SECTIONS */
section{padding:5rem 1.5rem}
.container{max-width:960px;margin:0 auto}
.section-label{font-size:.7rem;letter-spacing:4px;text-transform:uppercase;color:var(--clay);margin-bottom:1rem}
.section-title{font-family:'Playfair Display',serif;font-size:clamp(2rem,5vw,3rem);line-height:1.15;margin-bottom:1.5rem}

/* SERVICIOS */
.services{background:var(--cream)}
.services-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:2rem;margin-top:3rem}
.service-card{background:var(--warm-white);border-radius:16px;padding:2.5rem 2rem;border:1px solid rgba(46,31,20,.06);transition:all .35s}
.service-card:hover{transform:translateY(-4px);box-shadow:0 20px 50px rgba(46,31,20,.08)}
.service-icon{width:52px;height:52px;border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:1.5rem;margin-bottom:1.5rem}
.service-card:nth-child(1) .service-icon{background:rgba(196,112,75,.12)}
.service-card:nth-child(2) .service-icon{background:rgba(138,154,123,.15)}
.service-card:nth-child(3) .service-icon{background:rgba(201,168,76,.12)}
.service-card:nth-child(4) .service-icon{background:rgba(181,137,110,.12)}
.service-card h3{font-family:'Playfair Display',serif;font-size:1.25rem;margin-bottom:.75rem}
.service-card p{font-size:.9rem;line-height:1.6;color:#6b5b50;font-weight:300}

/* CÓMO FUNCIONA */
.how{background:var(--warm-white)}
.steps{display:flex;flex-direction:column;gap:2.5rem;margin-top:3rem;position:relative}
.steps::before{content:'';position:absolute;left:24px;top:0;bottom:0;width:1px;background:linear-gradient(to bottom,var(--clay),var(--sand))}
.step{display:flex;gap:1.5rem;align-items:flex-start}
.step-num{min-width:48px;height:48px;border-radius:50%;background:var(--espresso);color:var(--cream);display:flex;align-items:center;justify-content:center;font-family:'Playfair Display',serif;font-size:1.1rem;position:relative;z-index:1}
.step-content h3{font-size:1.05rem;font-weight:600;margin-bottom:.4rem}
.step-content p{font-size:.9rem;color:#6b5b50;font-weight:300;line-height:1.5}

/* PRECIOS */
.pricing{background:linear-gradient(175deg,var(--cream),var(--sand))}
.pricing-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(270px,1fr));gap:1.5rem;margin-top:3rem}
.price-card{background:var(--warm-white);border-radius:20px;padding:2.5rem 2rem;text-align:center;border:1px solid rgba(46,31,20,.06);position:relative;transition:all .35s;display:flex;flex-direction:column}
.price-card:hover{transform:translateY(-4px);box-shadow:0 20px 50px rgba(46,31,20,.08)}
.price-card.featured{border:2px solid var(--terracotta)}
.price-card.featured::after{content:'MÁS PEDIDO';position:absolute;top:-12px;left:50%;transform:translateX(-50%);background:var(--terracotta);color:white;padding:.3rem 1rem;border-radius:50px;font-size:.65rem;letter-spacing:2px;white-space:nowrap}
.price-card h3{font-family:'Playfair Display',serif;font-size:1.3rem;margin-bottom:.5rem}
.price-card .price{font-size:2.8rem;font-weight:700;color:var(--terracotta);margin:1rem 0 .25rem}
.price-card .price-note{font-size:.8rem;color:#9a8a7e;margin-bottom:1.5rem}
.price-card ul{list-style:none;text-align:left;margin-bottom:2rem;flex-grow:1}
.price-card li{padding:.5rem 0;font-size:.88rem;color:#6b5b50;border-bottom:1px solid rgba(46,31,20,.05);display:flex;align-items:center;gap:.5rem}
.price-card li::before{content:'✓';color:var(--sage);font-weight:700;font-size:.8rem}

/* CONTACTO */
.contact{background:var(--espresso);color:var(--cream);text-align:center}
.contact .section-label{color:var(--clay)}
.contact .section-title{color:var(--cream)}
.contact p{font-weight:300;font-size:1.05rem;max-width:500px;margin:0 auto 2rem;line-height:1.6;color:var(--sand)}
.contact-methods{display:flex;gap:1.5rem;justify-content:center;flex-wrap:wrap;margin-top:2rem}
.contact-pill{display:flex;align-items:center;gap:.6rem;padding:.8rem 1.8rem;border:1px solid rgba(232,221,211,.2);border-radius:50px;color:var(--sand);font-size:.9rem;text-decoration:none;transition:all .3s}
.contact-pill:hover{background:rgba(232,221,211,.1);border-color:var(--clay)}
.contact-pill .pill-icon{font-size:1.1rem}

/* FOOTER */
footer{background:var(--espresso);border-top:1px solid rgba(232,221,211,.08);padding:1.5rem;text-align:center;color:rgba(232,221,211,.35);font-size:.75rem;letter-spacing:1px}


/* PORTFOLIO */
.portfolio{background:var(--warm-white)}
.portfolio-intro{font-size:1.05rem;font-weight:300;color:#6b5b50;line-height:1.6;max-width:560px;margin-bottom:3rem}
.original-showcase{position:relative;margin-bottom:2.5rem;border-radius:20px;overflow:hidden;border:3px dashed var(--clay);padding:.5rem}
.original-showcase .original-img{width:100%;border-radius:16px;display:block}
.original-badge{position:absolute;top:1.2rem;left:1.2rem;background:var(--espresso);color:var(--cream);padding:.5rem 1.2rem;border-radius:50px;font-size:.75rem;letter-spacing:2px;font-weight:600;z-index:2}
.renders-label{font-family:'Playfair Display',serif;font-size:1.3rem;margin-bottom:1.5rem;color:var(--terracotta)}
.portfolio-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:1.2rem}
.portfolio-card{position:relative;border-radius:16px;overflow:hidden;border:1px solid rgba(46,31,20,.06);transition:all .35s}
.portfolio-card:hover{transform:translateY(-4px);box-shadow:0 20px 50px rgba(46,31,20,.1)}
.portfolio-card img{width:100%;display:block;aspect-ratio:4/3;object-fit:cover}
.portfolio-tag{position:absolute;bottom:.8rem;left:.8rem;background:rgba(46,31,20,.85);color:var(--cream);padding:.4rem 1rem;border-radius:50px;font-size:.75rem;letter-spacing:1px;font-weight:500;backdrop-filter:blur(8px)}


/* BRAND LOCKUP */
.brand-lockup{display:inline-block;text-align:left;margin-bottom:.5rem}
.studio-label{font-family:'Alex Brush',cursive;font-size:clamp(1.7rem,3.8vw,2.5rem);color:#63564b;padding-left:.55em;margin-bottom:-.4em;opacity:0;animation:fadeUp .8s .4s forwards}
.brand-name{display:flex;align-items:baseline;gap:.05em;opacity:0;animation:fadeUp .8s .5s forwards}
.brand-name .crea{font-family:'Cormorant SC',serif;font-size:clamp(4.3rem,11.4vw,8.5rem);font-weight:700;color:#63564b;letter-spacing:-.02em;line-height:.9}
.brand-name .en{font-family:'Alex Brush',cursive;font-size:clamp(2.65rem,6.6vw,4.75rem);color:#a36043;margin:0 .05em}
.brand-name .threed{font-family:'Playfair Display SC',serif;font-size:clamp(4.3rem,11.4vw,8.5rem);font-weight:700;color:#a36043;letter-spacing:-.02em;line-height:.9}

/* CONTACT FORM */
.contact-form{max-width:560px;margin:0 auto;text-align:left}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}
.form-group{margin-bottom:1.25rem}
.form-group label,.form-group>span#style-label{display:block;font-size:.8rem;font-weight:500;color:var(--sand);margin-bottom:.5rem;letter-spacing:.5px}
.form-group input,.form-group select,.form-group textarea{width:100%;padding:.9rem 1rem;border:1px solid rgba(232,221,211,.15);border-radius:12px;background:rgba(255,255,255,.08);color:var(--cream);font-family:inherit;font-size:.95rem;transition:all .25s}
.form-group input::placeholder,.form-group textarea::placeholder{color:rgba(232,221,211,.55)}
.form-group input:focus,.form-group select:focus,.form-group textarea:focus{outline:none;border-color:var(--clay);background:rgba(255,255,255,.12)}
.form-group select{cursor:pointer;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%23e8ddd3' d='M6 8L1 3h10z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 1rem center}
.form-group select option{background:var(--espresso);color:var(--cream)}
.form-group textarea{resize:vertical;min-height:80px}
.label-hint{font-weight:400;opacity:.6;font-size:.75rem}

/* STYLE SELECTOR */
.checkbox-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:.5rem;padding:1rem;border:1px solid rgba(232,221,211,.15);border-radius:12px;background:rgba(255,255,255,.03)}
.checkbox-item{position:relative}
.checkbox-item input{position:absolute;opacity:0;width:0;height:0}
.checkbox-item span{display:flex;align-items:center;justify-content:center;min-height:44px;padding:.5rem .75rem;border:1px solid rgba(232,221,211,.12);border-radius:8px;cursor:pointer;transition:all .2s;font-size:.85rem;color:var(--sand);background:rgba(255,255,255,.04);text-align:center}
.checkbox-item span:hover{border-color:rgba(232,221,211,.3);background:rgba(255,255,255,.08)}
.checkbox-item input:focus-visible+span{outline:2px solid var(--terracotta);outline-offset:2px}
.checkbox-item input:checked+span{background:var(--clay);border-color:var(--clay);color:var(--cream);font-weight:500}

/* DROPZONE */
.dropzone{border:2px dashed rgba(232,221,211,.25);border-radius:16px;padding:2rem;text-align:center;cursor:pointer;transition:all .25s}
.dropzone:hover,.dropzone.dragover{border-color:var(--clay);background:rgba(181,137,110,.1)}
.dropzone-content{display:flex;flex-direction:column;align-items:center;gap:.5rem}
.dropzone-icon{font-size:2rem;opacity:.7}
.dropzone-text{color:var(--sand);font-size:.95rem}
.dropzone-hint{color:rgba(232,221,211,.65);font-size:.75rem}
.dropzone.uploading{pointer-events:none;opacity:.7}

/* PREVIEW GRID */
.preview-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(100px,1fr));gap:.75rem;margin-top:1rem}
.preview-item{position:relative;aspect-ratio:1;border-radius:10px;overflow:hidden;background:rgba(255,255,255,.05)}
.preview-item img{width:100%;height:100%;object-fit:cover}
.preview-item .remove-btn{position:absolute;top:4px;right:4px;width:22px;height:22px;border-radius:50%;background:rgba(0,0,0,.6);border:none;color:white;font-size:14px;cursor:pointer;display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity .2s}
.preview-item:hover .remove-btn{opacity:1}
.preview-item .upload-progress{position:absolute;inset:0;background:rgba(0,0,0,.5);display:flex;align-items:center;justify-content:center}
.preview-item .upload-progress::after{content:'';width:24px;height:24px;border:2px solid transparent;border-top-color:white;border-radius:50%;animation:spin .8s linear infinite}
.preview-item.uploaded .upload-progress{display:none}
.preview-item.uploaded::after{content:'✓';position:absolute;bottom:4px;right:4px;width:20px;height:20px;background:var(--sage);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:11px;color:white}

/* SUBMIT BUTTON */
.btn-submit{width:100%;margin-top:1rem;padding:1.1rem;font-size:1rem;cursor:pointer}
.btn-submit:disabled{opacity:.6;cursor:not-allowed}
.btn-text[hidden],.btn-loading[hidden]{display:none}
.btn-loading{display:inline-flex;align-items:center;gap:.5rem}
.form-note{text-align:center;margin-top:1rem;font-size:.8rem;color:rgba(232,221,211,.7)}

/* SUCCESS STATE */
.form-success{text-align:center;padding:3rem 1rem}
.form-success .success-icon{display:inline-flex;align-items:center;justify-content:center;width:64px;height:64px;background:var(--sage);border-radius:50%;font-size:2rem;color:white;margin-bottom:1.5rem}
.form-success h3{font-family:'Playfair Display',serif;font-size:1.5rem;margin-bottom:.5rem}
.form-success p{color:var(--sand)}

@keyframes spin{to{transform:rotate(360deg)}}

/* ANIMATIONS */
@keyframes fadeUp{from{opacity:0;transform:translateY(24px)}to{opacity:1;transform:translateY(0)}}
@keyframes scrollPulse{0%,100%{opacity:.3;transform:scaleY(.6)}50%{opacity:1;transform:scaleY(1)}}

/* RESPONSIVE */
/* TABLET */
@media(max-width:900px){
  .services-grid{grid-template-columns:1fr 1fr}
  .portfolio-grid{grid-template-columns:repeat(2,1fr)}
  .pricing-grid{grid-template-columns:1fr}
  .price-card.featured{order:-1}
}

/* MOBILE */
@media(max-width:600px){
  section{padding:3.5rem 1.2rem}
  .services-grid{grid-template-columns:1fr}
  .portfolio-grid{grid-template-columns:1fr}
  .contact-methods{flex-direction:column;align-items:center}
  .form-row{grid-template-columns:1fr}
  .dropzone{padding:1.5rem 1rem}
  .checkbox-grid{grid-template-columns:repeat(2,1fr)}
  .dropzone-text{font-size:.85rem}
  .hero-cta{flex-direction:column;width:100%;max-width:280px}
  .hero-cta .btn{width:100%;text-align:center}
  .steps::before{left:20px}
  .step-num{min-width:40px;height:40px;font-size:1rem}
}

/* PRINT STYLES */
@media print{
  .hero{page-break-after:always;min-height:auto;padding:3rem 1.5rem}
  .services{page-break-after:always}
  .portfolio{page-break-before:always}
  .original-showcase{page-break-inside:avoid}
  .portfolio-grid{page-break-inside:avoid}
  .how{page-break-after:always}
  .pricing{page-break-before:always;page-break-after:always}
  .pricing-grid{page-break-inside:avoid}
  .price-card{page-break-inside:avoid}
  .service-card{page-break-inside:avoid}
  .step{page-break-inside:avoid}
  .contact{page-break-before:always}
  section{padding:2.5rem 1.5rem}
}
