/* =============================================
   CARITESHOP — Secciones y Componentes
   assets/css/sections.css
   ============================================= */

/* ---- HERO (Inicio) ---- */
.cs-hero {
  position:relative; height:100vh; min-height:600px;
  display:flex; align-items:center; justify-content:center; overflow:hidden;
}
.cs-hero-bg {
  position:absolute; inset:0;
  background:linear-gradient(160deg,#0d2535 0%,#1b4a62 35%,#1a6870 70%,#0d2535 100%);
  z-index:0;
}
.cs-hero-waves { position:absolute; inset:0; z-index:1; overflow:hidden; opacity:.18; }
.cs-hero-waves::before, .cs-hero-waves::after {
  content:''; position:absolute; width:200%; height:200%; border-radius:40%;
}
.cs-hero-waves::before {
  background:radial-gradient(ellipse at 60% 40%,rgba(64,164,162,.6) 0%,transparent 60%);
  animation:cs-wave1 18s ease-in-out infinite; top:-50%; left:-50%;
}
.cs-hero-waves::after {
  background:radial-gradient(ellipse at 40% 60%,rgba(48,99,127,.5) 0%,transparent 55%);
  animation:cs-wave2 24s ease-in-out infinite reverse; top:-60%; left:-40%;
}
@keyframes cs-wave1{0%,100%{transform:rotate(0deg);}50%{transform:rotate(8deg) scale(1.05);}}
@keyframes cs-wave2{0%,100%{transform:rotate(0deg);}50%{transform:rotate(-6deg) scale(1.08);}}
.cs-hero-overlay { position:absolute; inset:0; background:rgba(10,28,38,.55); z-index:2; }
.cs-hero-content {
  position:relative; z-index:3; text-align:center; color:#fff;
  padding:0 clamp(1.5rem,5vw,3rem); max-width:900px;
}
.cs-hero-eyebrow {
  display:flex; align-items:center; justify-content:center; gap:1rem;
  margin-bottom:2rem; opacity:0; animation:cs-fadeDown .9s ease .2s forwards;
}
.cs-hero-eyebrow::before,.cs-hero-eyebrow::after{
  content:''; flex:1; max-width:80px; height:1px; background:rgba(64,164,162,.6);
}
.cs-hero-eyebrow span{font-size:.65rem;letter-spacing:.3em;text-transform:uppercase;color:var(--cs-teal);font-weight:300;}
.cs-hero h1{opacity:0;animation:cs-fadeUp .9s ease .4s forwards;}
.cs-hero h1 em{color:var(--cs-teal);display:block;}
.cs-hero-sub{
  font-size:clamp(.95rem,2vw,1.1rem);font-weight:300;color:rgba(255,255,255,.75);
  max-width:540px;margin:1.5rem auto 0;
  opacity:0;animation:cs-fadeUp .9s ease .6s forwards;
}
.cs-hero-btns{
  display:flex;gap:1rem;justify-content:center;flex-wrap:wrap;margin-top:2.5rem;
  opacity:0;animation:cs-fadeUp .9s ease .8s forwards;
}
.cs-hero-scroll{
  position:absolute;bottom:2.5rem;left:50%;transform:translateX(-50%);
  z-index:3;display:flex;flex-direction:column;align-items:center;gap:.5rem;
  color:rgba(255,255,255,.45);font-size:.65rem;letter-spacing:.22em;text-transform:uppercase;
  animation:cs-bounce 2s ease infinite;
}
.cs-hero-scroll::after{content:'';width:1px;height:40px;background:rgba(64,164,162,.5);display:block;}
@keyframes cs-bounce{0%,100%{transform:translateX(-50%) translateY(0);}50%{transform:translateX(-50%) translateY(8px);}}
@keyframes cs-fadeUp{from{opacity:0;transform:translateY(24px);}to{opacity:1;transform:translateY(0);}}
@keyframes cs-fadeDown{from{opacity:0;transform:translateY(-16px);}to{opacity:1;transform:translateY(0);}}

/* ---- Colecciones ---- */
.cs-collections{padding:6rem 0;background:var(--cs-cream);}
.cs-section-header{margin-bottom:3rem;}
.cs-section-header h2{margin-bottom:.8rem;}
.cs-section-header p{color:var(--cs-gray);max-width:540px;margin:0 auto;}
.cs-collections-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem;margin-top:3rem;}
.cs-col-card{border-radius:8px;overflow:hidden;position:relative;cursor:pointer;transition:transform .35s ease,box-shadow .35s ease;background:#fff;}
.cs-col-card:hover{transform:translateY(-8px);box-shadow:var(--cs-shadow-lg);}
.cs-col-card-img{height:300px;position:relative;overflow:hidden;}
.cs-col-card-img img,.cs-col-bg{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;transition:transform .5s ease;}
.cs-col-card:hover .cs-col-bg,.cs-col-card:hover img{transform:scale(1.06);}
.cs-bg-caribe{background:linear-gradient(160deg,#0d3a5c 0%,#1a7a8a 40%,#40A4A2 100%);}
.cs-bg-playa{background:linear-gradient(160deg,#c4a35a 0%,#e8b86d 40%,#30637F 100%);}
.cs-bg-vista{background:linear-gradient(160deg,#E83D3E 0%,#c45a30 40%,#30637F 100%);}
.cs-col-svg{position:absolute;inset:0;width:100%;height:100%;opacity:.2;pointer-events:none;}
.cs-col-card-body{padding:1.5rem;}
.cs-col-card-body h3{margin-bottom:.5rem;}
.cs-col-card-body p{font-size:.88rem;color:var(--cs-gray);line-height:1.6;}
.cs-col-card-link{display:inline-flex;align-items:center;gap:.4rem;margin-top:1rem;font-size:.78rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--cs-teal);transition:gap var(--cs-ease);}
.cs-col-card-link:hover{gap:.7rem;}

/* ---- About strip ---- */
.cs-about-strip{
  background:linear-gradient(135deg,var(--cs-navy) 0%,var(--cs-dark) 100%);
  padding:6rem clamp(1.5rem,5vw,6rem);
  display:grid;grid-template-columns:1fr 1fr;gap:5rem;align-items:center;
}
.cs-about-strip h2{color:#fff;margin-bottom:1.2rem;}
.cs-about-strip p{color:rgba(255,255,255,.7);line-height:1.8;margin-bottom:1rem;}
.cs-about-tag{display:inline-block;background:rgba(64,164,162,.25);color:var(--cs-teal);padding:.35rem 1rem;border-radius:20px;font-size:.75rem;font-weight:700;letter-spacing:.12em;margin-top:.5rem;}
.cs-about-visual{position:relative;height:380px;border-radius:8px;overflow:hidden;background:linear-gradient(160deg,#1b4a62 0%,#40A4A2 100%);}
.cs-about-visual-inner{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;}
.cs-about-visual svg{width:180px;height:180px;opacity:.25;}
.cs-about-accent{position:absolute;bottom:2rem;right:2rem;background:var(--cs-coral);color:#fff;padding:1rem 1.5rem;border-radius:6px;text-align:center;}
.cs-about-accent strong{display:block;font-size:1.5rem;font-weight:900;font-style:italic;}
.cs-about-accent span{font-size:.7rem;letter-spacing:.15em;text-transform:uppercase;}

/* ---- Materials ---- */
.cs-materials{padding:6rem 0;background:var(--cs-cream);}
.cs-materials-inner{display:grid;grid-template-columns:1fr 1fr;gap:2rem;margin-top:3rem;}
.cs-mat-box{background:#fff;border-radius:8px;padding:2rem;border-top:3px solid var(--cs-teal);}
.cs-mat-box h4{font-size:.65rem;letter-spacing:.25em;text-transform:uppercase;color:var(--cs-teal);margin-bottom:1.2rem;font-weight:400;}
.cs-mat-list li{display:flex;align-items:center;gap:.8rem;padding:.7rem 0;border-bottom:1px solid var(--cs-light);font-size:.95rem;font-weight:300;}
.cs-mat-list li:last-child{border-bottom:none;}
.cs-dot{width:8px;height:8px;border-radius:50%;background:var(--cs-teal);flex-shrink:0;display:inline-block;}
.cs-size-grid{display:flex;flex-wrap:wrap;gap:.6rem;}
.cs-size-pill{background:var(--cs-cream);border:1px solid var(--cs-light);color:var(--cs-navy);padding:.4rem .9rem;border-radius:20px;font-size:.8rem;font-weight:700;transition:all var(--cs-ease);}
.cs-size-pill:hover,.cs-size-special{background:var(--cs-teal);color:#fff;border-color:var(--cs-teal);}

/* ---- CTA Banner ---- */
.cs-cta-banner{background:var(--cs-coral);padding:5rem clamp(1.5rem,5vw,6rem);text-align:center;color:#fff;position:relative;overflow:hidden;}
.cs-cta-banner h2{font-size:clamp(1.8rem,4vw,3rem);margin-bottom:1rem;}
.cs-cta-banner p{color:rgba(255,255,255,.85);max-width:540px;margin:0 auto 2rem;}

/* ---- Catálogo ---- */
.cs-catalog-section{padding:5rem 0 6rem;background:var(--cs-cream);}
.cs-filters-bar{background:#fff;padding:1.5rem clamp(1.5rem,5vw,6rem);border-bottom:1px solid var(--cs-light);position:sticky;top:var(--cs-nav-h);z-index:100;}
.cs-filters-inner{display:flex;align-items:center;gap:1rem;flex-wrap:wrap;}
.cs-filter-label{font-size:.7rem;letter-spacing:.22em;text-transform:uppercase;color:var(--cs-gray);font-weight:300;margin-right:.5rem;}
.cs-filter-btn{padding:.45rem 1.2rem;border-radius:20px;border:2px solid var(--cs-light);background:transparent;color:var(--cs-dark);font-family:var(--cs-font);font-size:.78rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;cursor:pointer;transition:all var(--cs-ease);}
.cs-filter-btn:hover{border-color:var(--cs-teal);color:var(--cs-teal);}
.cs-filter-btn.active{background:var(--cs-teal);border-color:var(--cs-teal);color:#fff;}
.cs-photos-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem;}
.cs-photo-card{background:#fff;border-radius:8px;overflow:hidden;box-shadow:var(--cs-shadow);transition:transform .35s ease,box-shadow .35s ease;}
.cs-photo-card:hover{transform:translateY(-6px);box-shadow:var(--cs-shadow-lg);}
.cs-photo-img{height:260px;position:relative;overflow:hidden;}
.cs-photo-img img{width:100%;height:100%;object-fit:cover;transition:transform .5s ease;}
.cs-photo-card:hover .cs-photo-img img{transform:scale(1.06);}
.cs-photo-placeholder{position:absolute;inset:0;background:linear-gradient(160deg,var(--cs-navy),var(--cs-teal));}
.cs-photo-num{position:absolute;top:1rem;left:1rem;background:rgba(0,0,0,.45);color:#fff;font-size:.68rem;font-weight:700;letter-spacing:.15em;padding:.3rem .7rem;border-radius:3px;}
.cs-photo-col-tag{position:absolute;top:1rem;right:1rem;font-size:.62rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;padding:.3rem .75rem;border-radius:3px;}
.cs-tag-caribe-divino{background:rgba(64,164,162,.9);color:#fff;}
.cs-tag-pa-la-playa{background:rgba(196,163,90,.9);color:#fff;}
.cs-tag-vista-bonita{background:rgba(232,61,62,.9);color:#fff;}
.cs-photo-info{padding:1.3rem 1.5rem 1.5rem;}
.cs-photo-info h3{font-size:1rem;margin-bottom:.3rem;}
.cs-col-name{font-size:.72rem;letter-spacing:.14em;text-transform:uppercase;color:var(--cs-teal);font-weight:300;display:block;margin-bottom:.3rem;}
.cs-photo-excerpt{font-size:.85rem;color:var(--cs-gray);margin:.5rem 0 0;}
.cs-cta-row{display:flex;align-items:center;justify-content:flex-end;margin-top:1rem;}
.cs-btn-small{font-size:.72rem;padding:.5rem 1rem;background:var(--cs-navy);color:#fff;border-radius:4px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;transition:all var(--cs-ease);}
.cs-btn-small:hover{background:var(--cs-teal);color:#fff;}

/* ---- Tienda / Configurador ---- */
.cs-store{padding:5rem 0 6rem;background:var(--cs-cream);}
.cs-store-intro{text-align:center;margin-bottom:4rem;}
.cs-steps{display:flex;align-items:flex-start;gap:0;margin-bottom:4rem;}
.cs-step{flex:1;text-align:center;position:relative;}
.cs-step::after{content:'→';position:absolute;top:1.2rem;right:-.3rem;font-size:1.2rem;color:var(--cs-light);font-weight:300;}
.cs-step:last-child::after{display:none;}
.cs-step-num{width:44px;height:44px;border-radius:50%;background:var(--cs-cream);border:2px solid var(--cs-teal);color:var(--cs-teal);font-weight:900;font-size:1rem;display:flex;align-items:center;justify-content:center;margin:0 auto .7rem;}
.cs-step p{font-size:.78rem;letter-spacing:.08em;text-transform:uppercase;color:var(--cs-gray);font-weight:400;}
.cs-configurator{display:grid;grid-template-columns:1fr 1.1fr;gap:3rem;align-items:start;}
.cs-config-preview{position:sticky;top:calc(var(--cs-nav-h) + 2rem);background:#fff;border-radius:12px;padding:2rem;box-shadow:var(--cs-shadow);}
.cs-preview-img{border-radius:6px;height:200px;display:flex;align-items:center;justify-content:center;margin-bottom:1.5rem;background:linear-gradient(160deg,var(--cs-navy),var(--cs-teal));transition:background .4s ease;}
.cs-preview-label{font-size:.65rem;letter-spacing:.22em;text-transform:uppercase;color:var(--cs-gray);margin-bottom:.3rem;display:block;}
.cs-preview-title{font-weight:700;font-size:1rem;margin-bottom:.2rem;}
.cs-preview-specs{font-size:.82rem;color:var(--cs-teal);}
.cs-preview-actions{margin-top:1.5rem;display:flex;gap:.8rem;flex-direction:column;}
.cs-config-panel{background:#fff;border-radius:10px;padding:1.8rem 2rem;margin-bottom:1.2rem;box-shadow:0 2px 12px rgba(48,99,127,.06);}
.cs-panel-header{display:flex;align-items:center;gap:1rem;margin-bottom:1.5rem;}
.cs-panel-num{width:30px;height:30px;border-radius:50%;background:var(--cs-teal);color:#fff;font-weight:900;font-size:.85rem;display:flex;align-items:center;justify-content:center;flex-shrink:0;}
.cs-panel-header h3{font-size:1rem;margin:0;}
.cs-photo-selector{display:grid;grid-template-columns:repeat(3,1fr);gap:.8rem;}
.cs-photo-option{border:2px solid var(--cs-light);border-radius:6px;overflow:hidden;cursor:pointer;transition:all var(--cs-ease);}
.cs-photo-option:hover{border-color:var(--cs-teal);}
.cs-photo-option.selected{border-color:var(--cs-teal);box-shadow:0 0 0 3px rgba(64,164,162,.2);}
.cs-photo-option .cs-thumb{height:70px;object-fit:cover;width:100%;}
.cs-photo-option .cs-thumb-bg{height:70px;display:flex;align-items:center;justify-content:center;font-size:1.5rem;}
.cs-thumb-label{font-size:.65rem;text-align:center;padding:.4rem;color:var(--cs-dark);font-weight:700;}
.cs-mat-options{display:flex;flex-direction:column;gap:.7rem;}
.cs-mat-option{border:2px solid var(--cs-light);border-radius:8px;padding:1rem 1.2rem;cursor:pointer;display:flex;align-items:center;gap:1rem;transition:all var(--cs-ease);}
.cs-mat-option:hover{border-color:var(--cs-teal);}
.cs-mat-option.selected{border-color:var(--cs-teal);background:rgba(64,164,162,.06);}
.cs-mat-icon{font-size:1.4rem;flex-shrink:0;}
.cs-mat-info h4{font-size:.9rem;margin-bottom:.15rem;}
.cs-mat-info p{font-size:.75rem;color:var(--cs-gray);margin:0;}
.cs-size-options{display:flex;flex-wrap:wrap;gap:.6rem;}
.cs-size-option{border:2px solid var(--cs-light);border-radius:6px;padding:.5rem 1rem;cursor:pointer;font-size:.82rem;font-weight:700;color:var(--cs-navy);transition:all var(--cs-ease);background:transparent;}
.cs-size-option:hover{border-color:var(--cs-teal);color:var(--cs-teal);}
.cs-size-option.selected{border-color:var(--cs-teal);background:var(--cs-teal);color:#fff;}
.cs-size-option.cs-special{border-color:var(--cs-coral);color:var(--cs-coral);}
.cs-size-option.cs-special.selected{background:var(--cs-coral);color:#fff;border-color:var(--cs-coral);}
.cs-pay-options{display:flex;gap:1rem;flex-wrap:wrap;}
.cs-pay-option{border:2px solid var(--cs-light);border-radius:8px;padding:.8rem 1.4rem;cursor:pointer;display:flex;align-items:center;gap:.6rem;font-size:.85rem;font-weight:700;transition:all var(--cs-ease);background:transparent;font-family:var(--cs-font);}
.cs-pay-option:hover{border-color:var(--cs-teal);}
.cs-pay-option.selected{border-color:var(--cs-teal);background:rgba(64,164,162,.08);}

/* ---- Formularios ---- */
.cs-cf,.cs-order-form{display:flex;flex-direction:column;gap:1.1rem;}
.cs-form-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem;}
.cs-form-group{display:flex;flex-direction:column;gap:.4rem;}
.cs-form-group label{font-size:.7rem;letter-spacing:.18em;text-transform:uppercase;color:var(--cs-gray);font-weight:400;}
.cs-form-group input,.cs-form-group select,.cs-form-group textarea{border:2px solid var(--cs-light);border-radius:6px;padding:.75rem 1rem;font-family:var(--cs-font);font-size:.9rem;font-weight:300;background:var(--cs-cream);color:var(--cs-dark);transition:border var(--cs-ease);outline:none;}
.cs-form-group input:focus,.cs-form-group select:focus,.cs-form-group textarea:focus{border-color:var(--cs-teal);}
.cs-form-group textarea{min-height:120px;resize:vertical;}
.cs-info-box{background:rgba(64,164,162,.08);border-left:3px solid var(--cs-teal);border-radius:0 6px 6px 0;padding:1rem 1.2rem;font-size:.85rem;color:var(--cs-navy);line-height:1.6;}
.cs-contact-method{background:#fff;border-radius:10px;padding:1.5rem;margin-bottom:1rem;display:flex;align-items:center;gap:1.2rem;box-shadow:0 2px 12px rgba(48,99,127,.06);transition:transform var(--cs-ease),box-shadow var(--cs-ease);text-decoration:none;color:inherit;}
.cs-contact-method:hover{transform:translateY(-3px);box-shadow:var(--cs-shadow);}
.cs-cm-icon{font-size:1.8rem;flex-shrink:0;}
.cs-cm-info h4{font-size:.95rem;margin-bottom:.2rem;}
.cs-cm-info span{font-size:.82rem;color:var(--cs-gray);}
.cs-cm-arrow{margin-left:auto;color:var(--cs-teal);font-size:1.2rem;}
.cs-success-panel{text-align:center;padding:3rem 2rem;}
.cs-success-icon{font-size:3rem;margin-bottom:1rem;}
.cs-success-panel h3{color:var(--cs-teal);margin-bottom:.5rem;}
.cs-success-panel p{color:var(--cs-gray);}
.cs-contact-form-wrap{background:#fff;border-radius:12px;padding:2.5rem;box-shadow:var(--cs-shadow);}

/* ---- Página: Sobre ---- */
.cs-slug-sobre .cs-page-content{padding:6rem 0;background:var(--cs-cream);}
.cs-story-grid{display:grid;grid-template-columns:1fr 1fr;gap:5rem;align-items:start;max-width:1200px;margin:0 auto;padding:0 clamp(1.5rem,5vw,4rem);}
.cs-story-text h3{margin-bottom:1rem;color:var(--cs-navy);}
.cs-story-text p{color:var(--cs-gray);line-height:1.85;margin-bottom:1.2rem;}
.cs-quote-block{background:#fff;border-left:4px solid var(--cs-teal);border-radius:0 8px 8px 0;padding:1.8rem 2rem;margin:2rem 0;}
.cs-quote-block p{font-size:1.1rem;font-weight:400;font-style:italic;color:var(--cs-navy);margin:0;}
.cs-photographer-card{background:#fff;border-radius:12px;overflow:hidden;box-shadow:var(--cs-shadow);}
.cs-photographer-img{height:300px;background:linear-gradient(160deg,var(--cs-navy),var(--cs-teal));display:flex;align-items:center;justify-content:center;overflow:hidden;}
.cs-photographer-img img{width:100%;height:100%;object-fit:cover;}
.cs-photographer-info{padding:1.8rem;}
.cs-photographer-info h3{margin-bottom:.3rem;}
.cs-photographer-role{font-size:.75rem;letter-spacing:.18em;text-transform:uppercase;color:var(--cs-teal);font-weight:400;margin-bottom:1rem;display:block;}
.cs-photographer-info p{font-size:.9rem;color:var(--cs-gray);line-height:1.7;}
.cs-social-links{display:flex;gap:1rem;margin-top:1.2rem;flex-wrap:wrap;}
.cs-social-link{display:inline-flex;align-items:center;gap:.4rem;font-size:.78rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--cs-navy);padding:.45rem 1rem;border:1px solid var(--cs-light);border-radius:4px;transition:all var(--cs-ease);text-decoration:none;}
.cs-social-link:hover{background:var(--cs-teal);color:#fff;border-color:var(--cs-teal);}
.cs-values{padding:5rem 0;background:#fff;}
.cs-values-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:2rem;margin-top:3rem;}
.cs-value-card{padding:2rem;border-radius:8px;background:var(--cs-cream);border-top:3px solid var(--cs-teal);}
.cs-value-icon{font-size:2rem;margin-bottom:1rem;}
.cs-value-card h4{margin-bottom:.6rem;font-size:1rem;}
.cs-value-card p{font-size:.88rem;color:var(--cs-gray);line-height:1.7;}

/* ---- Responsive ---- */
@media(max-width:900px){
  .cs-collections-grid,.cs-about-strip,.cs-materials-inner,
  .cs-configurator,.cs-story-grid{grid-template-columns:1fr;gap:2.5rem;}
  .cs-about-visual,.cs-config-preview{position:static;height:260px;}
  .cs-photos-grid{grid-template-columns:1fr 1fr;}
  .cs-values-grid{grid-template-columns:1fr 1fr;}
}
@media(max-width:540px){
  .cs-photos-grid,.cs-photo-selector{grid-template-columns:1fr;}
  .cs-form-row{grid-template-columns:1fr;}
  .cs-values-grid{grid-template-columns:1fr;}
  .cs-steps{flex-wrap:wrap;justify-content:center;}
  .cs-step{min-width:45%;}
}
