/*
Theme Name: Shoptimizer Child
Template: shoptimizer
Description: Child theme for 3dclypse.fr
Version: 1.0
*/

/* Cart icon orange */
.shoptimizer-cart .cart-contents,
.shoptimizer-cart .cart-contents svg,
.shoptimizer-cart .cart-contents path {
  color: #f05a00 !important;
  fill: #f05a00 !important;
  stroke: #f05a00 !important;
}
.shoptimizer-cart .cart-contents .count {
  background-color: #f05a00 !important;
  color: #fff !important;
}
.shoptimizer-cart .cart-contents .amount {
  color: #f05a00 !important;
}

/* Mobile responsive fixes */
@media (max-width: 768px) {
  .cedia3d-page .hero-inner { grid-template-columns: 1fr !important; }
  .cedia3d-page .hero-left { text-align: center; }
  .cedia3d-page .hero-left h1 { font-size: 1.8rem !important; }
  .cedia3d-page .svc-grid { grid-template-columns: 1fr !important; }
  .cedia3d-page .tarif-grid { grid-template-columns: 1fr !important; }
  .cedia3d-page .gal-grid { grid-template-columns: 1fr 1fr !important; }
  .cedia3d-page .steps-wrap { flex-direction: column !important; gap: 20px !important; }
  .cedia3d-page .prod-showcase { grid-template-columns: 1fr 1fr !important; }
}
@media (max-width: 480px) {
  .cedia3d-page .gal-grid { grid-template-columns: 1fr !important; }
  .cedia3d-page .prod-showcase { grid-template-columns: 1fr !important; }
}

/* Contact Form 7 - Devis 3D styling */
.devis-form { max-width: 800px; margin: 0 auto; }
.devis-form h3 { color: #f05a00; font-size: 1.2rem; margin: 30px 0 15px; padding-bottom: 8px; border-bottom: 2px solid #f05a00; }
.devis-form .form-row { display: flex; gap: 20px; margin-bottom: 15px; }
.devis-form .form-col { flex: 1; }
.devis-form label { display: block; font-weight: 600; margin-bottom: 5px; color: #0f2044; font-size: 0.9rem; }
.devis-form input[type=text],
.devis-form input[type=email],
.devis-form input[type=tel],
.devis-form input[type=number],
.devis-form select,
.devis-form textarea { width: 100%; padding: 12px; border: 1px solid #ddd; border-radius: 8px; font-size: 0.95rem; transition: border-color 0.3s; }
.devis-form input:focus,
.devis-form select:focus,
.devis-form textarea:focus { border-color: #f05a00; outline: none; box-shadow: 0 0 0 3px rgba(240,90,0,.1); }
.devis-form textarea { min-height: 120px; resize: vertical; }
.devis-form input[type=submit] { background: #f05a00; color: #fff; border: none; padding: 15px 40px; border-radius: 8px; font-size: 1.1rem; font-weight: 700; cursor: pointer; margin-top: 20px; transition: background 0.3s; }
.devis-form input[type=submit]:hover { background: #d04e00; }
.devis-form .wpcf7-response-output { border-radius: 8px; padding: 15px; margin-top: 20px; }
.devis-form .wpcf7-not-valid-tip { color: #e74c3c; font-size: 0.85rem; }
@media (max-width: 768px) {
  .devis-form .form-row { flex-direction: column; gap: 10px; }
}

/* === F90 — CF7 Form 3DClypse === */
.wpcf7-form .wpcf7-form-control-wrap,
.wpcf7-form p {
    margin-bottom: 16px;
}
.wpcf7-form input[type="text"],
.wpcf7-form input[type="email"],
.wpcf7-form input[type="tel"],
.wpcf7-form select,
.wpcf7-form textarea {
    width: 100%;
    padding: 14px 18px;
    border: 2px solid #e2e8f0;
    border-radius: 10px;
    font-family: Inter, sans-serif;
    font-size: 15px;
    color: #0a1628;
    background: #fff;
    transition: border-color .2s, box-shadow .2s;
    outline: none;
    box-sizing: border-box;
}
.wpcf7-form input:focus,
.wpcf7-form textarea:focus,
.wpcf7-form select:focus {
    border-color: #f26b2b;
    box-shadow: 0 0 0 3px rgba(242,107,43,.12);
}
.wpcf7-form textarea {
    min-height: 130px;
    resize: vertical;
}
.wpcf7-form input[type="submit"],
.wpcf7-form .wpcf7-submit {
    background: #f26b2b;
    color: #fff;
    border: none;
    border-radius: 10px;
    padding: 15px 36px;
    font-family: Inter, sans-serif;
    font-size: 16px;
    font-weight: 700;
    cursor: pointer;
    transition: background .2s, transform .1s;
    width: 100%;
}
.wpcf7-form input[type="submit"]:hover,
.wpcf7-form .wpcf7-submit:hover {
    background: #d95a1e;
    transform: translateY(-1px);
}
.wpcf7-form label {
    display: block;
    font-family: Inter, sans-serif;
    font-size: 13px;
    font-weight: 600;
    color: #0a1628;
    margin-bottom: 6px;
    letter-spacing: .3px;
}
.wpcf7-not-valid-tip {
    color: #e53e3e;
    font-size: 12px;
    margin-top: 4px;
    display: block;
}
.wpcf7-form .wpcf7-response-output {
    border-radius: 10px;
    padding: 12px 18px;
    margin-top: 16px;
    font-size: 14px;
    font-family: Inter, sans-serif;
}

/* === G99 — Micro-interactions 3DClypse === */
/* Cards service pages */
.cedia3d-page .service-card,
.cedia3d-page .avantage-item,
.cedia3d-page .material-card,
.cedia3d-page .faq-item {
    transition: transform .2s ease, box-shadow .2s ease;
}
.cedia3d-page .service-card:hover,
.cedia3d-page .avantage-item:hover {
    transform: translateY(-4px);
    box-shadow: 0 12px 32px rgba(0,0,0,.1);
}
/* Boutons */
.cedia3d-page .btn-primary,
.cedia3d-page .cta-btn,
.cedia3d-page a.btn-orange {
    transition: background .2s, transform .15s, box-shadow .2s;
}
.cedia3d-page .btn-primary:hover,
.cedia3d-page .cta-btn:hover,
.cedia3d-page a.btn-orange:hover {
    transform: translateY(-2px);
    box-shadow: 0 6px 20px rgba(242,107,43,.35);
}
/* Liens footer */
footer.site-footer a:not(.button) {
    transition: color .15s, padding-left .15s;
}
footer.site-footer a:not(.button):hover {
    padding-left: 4px;
}
/* Reviews / avis */
.cedia3d-page .review-card,
.cedia3d-page .temo-card {
    transition: transform .2s, box-shadow .2s;
}
.cedia3d-page .review-card:hover,
.cedia3d-page .temo-card:hover {
    transform: translateY(-3px);
    box-shadow: 0 10px 28px rgba(0,0,0,.09);
}
/* Below-content USP */
.below-content .widget {
    transition: transform .2s;
}
.below-content .widget:hover {
    transform: translateY(-2px);
}

/* === FAQ accordéon catégories === */
.tdcl-faq{margin-top:40px;border-top:2px solid #f26b2b;padding-top:24px;}
.tdcl-faq h3{font-size:1.2em;color:#0a1628;margin-bottom:16px;}
.tdcl-faq details{border:1px solid #e8e8e8;border-radius:6px;margin-bottom:8px;overflow:hidden;}
.tdcl-faq summary{padding:14px 18px;font-weight:600;cursor:pointer;list-style:none;background:#f9f9f9;color:#0a1628;display:flex;justify-content:space-between;align-items:center;}
.tdcl-faq summary::-webkit-details-marker{display:none;}
.tdcl-faq summary::after{content:"+";font-size:1.3em;color:#f26b2b;transition:.2s;}
.tdcl-faq details[open] summary::after{content:"-";}
.tdcl-faq details p{padding:14px 18px;margin:0;color:#444;line-height:1.7;font-size:.95em;}

/* === Images produit carrées === */
.woocommerce-product-gallery .woocommerce-product-gallery__image img,
.woocommerce-product-gallery__image img {
    aspect-ratio: 1 / 1;
    object-fit: cover;
    width: 100%;
}

/* === Couleurs brand sur bouton flottant === */
.shoptimizer-floating-bar__button,
button[data-trigger="callBack"],
.shoptimizer-floating-bar .button {
    background-color: #f26b2b !important;
    color: #fff !important;
    border-color: #f26b2b !important;
}
.shoptimizer-floating-bar__button:hover,
button[data-trigger="callBack"]:hover {
    background-color: #d55a1f !important;
}
