/* This file if for the Urbafence configurator only (with claude) */

button:hover,button:focus{background:#35823F !important;color: #fff !important;}
/* Stepper intégré dans form-title */
.st-item{display:flex;align-items:center;gap:5px;cursor:pointer;flex:1;justify-content:center;padding:0 2px;}
.st-sep{width:1px;height:16px;background:rgba(255,255,255,0.25);flex-shrink:0;}
.st-num{width:20px;height:20px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:15px;font-weight:500;flex-shrink:0;}
.st-label{font-size:17px;color:#fff;white-space:nowrap;}
.st-item.active .st-num{background:#fff;color:#35823F;}
.st-item.done .st-num{background:rgba(255,255,255,0.85);color:#35823F;}
.st-item.idle .st-num{background:rgba(255,255,255,0.18);color:#fff;}
.st-item.idle .st-label{opacity:0.5;}
.st-item.done .st-label{opacity:0.75;}

/* ShapeDiver*/
#sdv-container-in-panel {width: 1150px;height: 650px;}

/* Layout */
.main-layout{display:flex;width:100%;min-height:650px;}
.form-body{padding:8px 14px 14px;overflow-y:auto;max-height:calc(650px - 46px);}
.form-toggle-band{width:22px;flex-shrink:0;background:#35823F;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .15s;z-index:10;}
.form-toggle-band:hover{background:#2a6832;}
.form-toggle-band span{color:#fff;font-size:15px;font-weight:500;white-space:nowrap;transform:rotate(-90deg);letter-spacing:.05em;user-select:none;}
.form-panel{width:0;overflow:hidden;transition:width .3s ease;background:#fff;border-right:1px solid #ddd;flex-shrink:0;}
.form-panel.open{width:calc(60% - 22px);}
.form-inner{min-width:300px;}
.form-title{background:#35823F;padding:0 10px;height:44px;display:flex;align-items:center;justify-content:space-between;gap:4px;}

.gc-bloc{display:none;}
.gc-bloc.active{display:block;}

/* Champs */
.form-row{margin-bottom:8px;position:relative;}
.form-row label,.sub-sec label{display:block;font-size:12px;color:#666;margin-bottom:2px;}
.form-row input,.form-row select{width:100%;padding:4px 7px;font-size:13px;border:1px solid #ccc;border-radius:3px;background:#fff;color:#3c3c3c;}
.form-row input::placeholder{color:#ccc;font-style:italic;}
.form-row input:focus,.form-row select:focus{outline:none;border-color:#35823F;box-shadow:0 0 0 2px rgba(53,130,63,.15);}
.form-row.has-error input,.form-row.has-error select,.form-row.has-error-platine input,.form-row.has-error-platine select,.form-row.has-error-tube input,.form-row.has-error-tube select{border-color:#c0392b;}
.field-error,.field-error-platine,.field-error-tube,.field-error-section{font-size:10px;color:#c0392b;margin-top:2px;display:none;}
.form-row.has-error .field-error{display:block;}
.form-row.has-error-platine .field-error-platine,.form-row.has-error-tube .field-error-tube{display:block !important;}
.form-row.has-error-platine .field-error-tube,.form-row.has-error-tube .field-error-platine{display:none !important;}
.form-row:not(.has-error-platine) .field-error-platine,.form-row:not(.has-error-tube) .field-error-tube{display:none !important;}
.field-required{color:#c0392b;margin-left:2px;}
.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:8px;}

/* Info bulle */
.label-row{display:flex;align-items:center;gap:4px;margin-bottom:2px;}
.label-row label{margin-bottom:0;}
.info-icon{width:14px;height:14px;border-radius:50%;background:#9BC391;color:#fff;font-size:9px;font-weight:700;display:inline-flex;align-items:center;justify-content:center;cursor:pointer;flex-shrink:0;position:relative;}
.info-tooltip{display:none;position:absolute;left:-30px;top:20px;background:#3c3c3c;color:#fff;font-size:12px;line-height:1.4;padding:7px 10px;border-radius:4px;width:240px;z-index:50;font-weight:400;}
.info-tooltip:before{content:"";position:absolute;left:-5px;top:10px;border:5px solid transparent;border-right-color:#3c3c3c;border-left:none;}
.info-icon:hover .info-tooltip{display:block;}

/* Conditionnel */
.cond{border-left:3px solid #35823F;padding:6px 8px;margin:4px 0 8px;background:#f0f7f1;border-radius:0 3px 3px 0;display:none;}
.cond.on{display:block;}

/* Sections */
.sub-sec{border:1px solid #e0e0e0;border-radius:4px;padding:8px 10px;margin-bottom:8px;}
.sub-sec-title{font-size:12px;font-weight:500;color:#35823F;text-transform:uppercase;letter-spacing:.04em;margin-bottom:7px;}
.piece-title{font-size:12px;font-weight:500;color:#35823F;margin-bottom:5px;}

/* Info bloc tube */
.info-block{background:#f0f7f1;border:1px solid #9BC391;border-radius:3px;padding:6px 8px;font-size:12px;color:#35823F;line-height:1;margin-top:4px;margin-bottom:6px;}

/* Optionnel */
.opt-blk{border:1px dashed #ccc;border-radius:4px;padding:6px 10px;margin-bottom:7px;background:#fafafa;}
.opt-blk.on{background:#fff;border-style:solid;border-color:#9BC391;}
.opt-head{display:flex;align-items:center;justify-content:space-between;font-size:12px;color:#666;}
.opt-content{display:none;margin-top:7px;}
.opt-blk.on .opt-content{display:block;}
.btn-opt{background:none;border:1px solid #ccc;border-radius:3px;padding:2px 8px;font-size:12px;color:#666;cursor:pointer;}
.btn-opt:hover{background:#35823F;border-color:#35823F;color:#35823F;}

/* Radio */
.radio-grp{display:flex;gap:6px;margin-bottom:10px;}
.radio-opt{display:flex;align-items:center;gap:5px;cursor:pointer;padding:4px 10px;border:1px solid #ccc;border-radius:3px;font-size:13px;background:#fafafa;}
.radio-opt.on{border-color:#35823F;background:#f0f7f1;color:#35823F;font-weight:500;}
.rdot{width:12px;height:12px;border-radius:50%;border:1px solid #ccc;display:flex;align-items:center;justify-content:center;flex-shrink:0;}
.radio-opt.on .rdot{border-color:#35823F;}
.rdot-inner{width:5px;height:5px;border-radius:50%;background:#35823F;display:none;}
.radio-opt.on .rdot-inner{display:block;}

/* Radio buttons */
.radio-btn-grp {display: flex;flex-wrap: wrap;gap: 5px;}
.radio-btn {display: flex;align-items: center;gap: 6px;cursor: pointer;padding: 4px 9px;border: 1px solid #ccc;border-radius: 3px;font-size: 12px;background: #fafafa;white-space: nowrap;transition: border-color .15s, background .15s, color .15s;}
.radio-btn input[type="radio"] {accent-color: #35823F;width: 13px;height: 13px;margin: 0;cursor: pointer;}
.radio-btn:has(input:checked) {border-color: #35823F;background: #f0f7f1;color: #35823F;font-weight: 500;}


/* Preview motif/couleur */
.preview-line{display:flex;align-items:center;gap:8px;padding:5px 8px;background:#f9f9f9;border:1px solid #e8e8e8;border-radius:4px;margin-bottom:8px;}
.prev-thumb,.prev-swatch{width:80px;height:80px;border-radius:3px;flex-shrink:0;}
.prev-thumb{background:#eee;border:1px solid #ddd;display:flex;align-items:center;justify-content:center;}
.prev-swatch{border:1px solid #ddd;}
.prev-meta{flex:1;min-width:0;}
.prev-name{font-size:12px;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.prev-sub{font-size:10px;color:#888;}
.btn-chg{background:none;border:1px solid #ccc;border-radius:3px;padding:2px 8px;font-size:12px;color:#666;cursor:pointer;white-space:nowrap;flex-shrink:0;}
.btn-chg:hover,.btn-chg:focus{border-color:#35823F;background:#35823F;}

/* Platines */
.plat-grid{display:grid;grid-template-columns:1fr 1fr;gap:5px;margin-top:5px;}
.plat-card{border:1px solid #e0e0e0;border-radius:3px;padding:5px;cursor:pointer;display:flex;gap:5px;align-items:flex-start;background:#fff;font-size:12px;position:relative;}
.plat-card:hover{border-color:#35823F;}
.plat-card.sel{border:1px solid #35823F;background:#f0f7f1;}
.plat-img{opacity:.25;width:50px;height:50px;border-radius:3px;background:#f5f5f5;border:1px solid #e8e8e8;display:flex;align-items:center;justify-content:center;flex-shrink:0;cursor:zoom-in;}
.plat-ref{font-weight:500;color:#3c3c3c;}
.plat-desc{font-size:10px;color:#888;line-height:1.3;}
.plat-badge{font-size:9px;padding:0 4px;border-radius:8px;background:#f0f7f1;color:#35823F;border:0.5px solid #9BC391;margin-top:2px;}
.plat-check{width:12px;height:12px;border-radius:50%;border:1px solid #ccc;flex-shrink:0;margin-top:1px;}
.plat-card.sel .plat-check{background:#35823F;border-color:#35823F;}
.plat-summary{display:none;align-items:center;gap:6px;padding:4px 8px;background:#f0f7f1;border:1px solid rgba(53,130,63,.3);border-radius:3px;margin-top:5px;font-size:12px;}
.plat-summary.on{display:flex;}
.plat-sum-img{width:24px;height:24px;border-radius:3px;background:#f5f5f5;border:1px solid #e8e8e8;display:flex;align-items:center;justify-content:center;flex-shrink:0;}
.plat-sum-txt{flex:1;font-weight:500;}

/* Toggles */
.toggle-row{display:flex;align-items:center;justify-content:space-between;padding:6px 0;border-bottom:1px solid #f0f0f0;font-size:13px;}
.toggle-row:last-child{border-bottom:none;}
.sw{display:inline-block;height:22px;position:relative;width:46px;flex-shrink:0;}
.sw input{opacity:0;width:0;height:0;position:absolute;}
.slider{background:#ccc;bottom:0;cursor:pointer;left:0;position:absolute;right:0;top:0;transition:.3s;border-radius:22px;}
.slider:before{background:#fff;bottom:3px;content:"";height:16px;left:3px;position:absolute;transition:.3s;width:16px;border-radius:50%;}
input:checked+.slider{background:#35823F;}
input:checked+.slider:before{transform:translateX(24px);}

/* Bravo */
.bravo-msg{background:#f0f7f1;border:1px solid rgba(53,130,63,.3);border-radius:4px;padding:8px 10px;margin-bottom:10px;font-size:12px;line-height:1;}
.bravo-msg strong{display:block;font-size:13px;margin-bottom:2px;color:#35823F;}

/* Nav */
.nav-btns{display:flex;justify-content:space-between;align-items:center;margin-top:10px;}
.btn-primary{background-color:#35823F !important;border:none;padding:6px 16px;border-radius:3px;font-size:13px;cursor:pointer;font-weight:500;text-transform:uppercase;}
.btn-primary:hover{background-color:#2a6832 !important;}
.btn-back{background:none;border:1px solid #ccc;border-radius:3px;padding:5px 10px;font-size:12px;color:#666;cursor:pointer;}
.btn-back:hover,.btn-back:focus{border-color:#35823F;background:#35823F;}
.btn-panier{background-color:#35823F !important;color:#fff;border:none;width:70%;padding:5px;border-radius:3px;font-size:14px;cursor:pointer;font-weight:500;text-transform:uppercase;margin-top:9px;margin-right:15px;transition:background .2s,opacity .2s;}
.btn-panier:hover:not(:disabled){background-color:#2a6832 !important;}
.btn-panier:disabled{opacity:.45;cursor:not-allowed;}
#project_infos .btn-panier{width: 100%;}

/* Zone 3D */
.sdv-panel{flex:1;background:#e8e8e8;display:flex;align-items:center;justify-content:center;flex-direction:column;gap:8px;position:relative;overflow:hidden;}
.sdv-inner{display:flex;flex-direction:column;align-items:center;gap:8px;transition:filter .3s,opacity .3s;}
.sdv-panel.outdated .sdv-inner{filter:blur(3px);opacity:.6;}
.sdv-banner{display:none;position:absolute;top:0;left:0;right:0;background:rgba(53,130,63,.92);color:#fff;font-size:12px;font-weight:500;padding:7px 12px;align-items:center;justify-content:space-between;gap:10px;z-index:5;}
.sdv-panel.outdated .sdv-banner{display:flex;}
.btn-refresh{background:#fff;color:#35823F;border:none;border-radius:3px;padding:4px 12px;font-size:12px;font-weight:500;cursor:pointer;display:flex;align-items:center;gap:5px;flex-shrink:0;}
.btn-refresh:hover{background:#35823F;}
.sdv-spinner{display:none;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);background:rgba(255,255,255,.92);border-radius:8px;padding:16px 24px;font-size:13px;color:#35823F;font-weight:500;align-items:center;gap:10px;z-index:6;}
.sdv-panel.loading .sdv-spinner{display:flex;}
.sdv-panel.loading .sdv-inner{filter:blur(2px);opacity:.4;}
.sdv-panel.loading .sdv-banner{display:none;}
@keyframes spin{to{transform:rotate(360deg);}}
.spin-icon{width:18px;height:18px;border:2px solid #9BC391;border-top-color:#35823F;border-radius:50%;animation:spin .7s linear infinite;}


/* Modales */
.modal{display:none;position:fixed;top:0;left:0;width:100%;height:100%;background:rgba(0,0,0,.4);z-index:1000;overflow:auto;}
.modal.on{display:block;}
.modal-content{background:#fff;border:1px solid #888;border-radius:12px;margin:5% auto;padding:0;width:52%;max-height:calc(100vh - 200px);overflow-y:auto;}
.modal-header{padding:12px 16px;border-bottom:1px solid #e8e8e8;border-radius:12px 12px 0 0;display:flex;align-items:center;justify-content:space-between;}
.modal-header h2{font-size:15px;margin:0;}
.modal-close{background:none;border:none;font-size:22px;cursor:pointer;color:#666;margin-left: auto;flex-shrink: 0;}
.Tfilters{margin-bottom:10px;}
.Tfilters button{margin-bottom:5px;}
.filtre{border:1px solid #9BC391;margin-right:5px;margin-bottom:6px;padding:2px 10px;border-radius:3px;font-size:15px;color:#35823F;cursor:pointer;background:#f0f7f1;}
.filtre.on,.filtre:hover{background:#35823F;color:#fff;border-color:#35823F;}
.motif-grid-m{display:grid;grid-template-columns:repeat(3,1fr);gap:7px;}
.motif-item{border:1px solid #e0e0e0;border-radius:4px;overflow:hidden;cursor:pointer;}
.motif-item:hover,.motif-item.sel{border-color:#35823F;}
.motif-item.sel{border-width:2px;}
.motif-item-img{background:#f5f5f5;display:flex;align-items:center;justify-content:center;}
.motif-item-info{padding:4px 5px;font-size:12px;}
.motif-item-info div{height: 16px}
.motif-item-name{font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.modal-search{margin-bottom:10px;}
.modal-search input{width:100%;padding:4px 8px;border:1px solid #ccc;border-radius:3px;font-size:12px;margin-bottom:10px;}
.ral-group{margin-bottom:12px;}
.ral-group-name{font-size:10px;font-weight:500;color:#888;text-transform:uppercase;margin-bottom:5px;}
.ral-swatches{display:flex;flex-wrap:wrap;gap:5px;}
.ral-item{display:flex;flex-direction:column;align-items:center;gap:2px;cursor:pointer;}
.ral-swatch{width:30px;height:30px;border-radius:4px;border:1px solid #ddd;transition:transform .12s;}
.ral-item:hover .ral-swatch{transform:scale(1.12);}
.ral-item.sel .ral-swatch{outline:2px solid #35823F;outline-offset:1px;}
.ral-code{font-size:9px;color:#999;}
#uf-modal-motif .modal-body {display: flex;flex-direction: column;}


/* Lightbox */
.lb-overlay{display:none;position:fixed;top:0;left:0;width:100%;height:100%;background:rgba(0,0,0,.5);z-index:2000;align-items:center;justify-content:center;}
.lb-overlay.on{display:flex;}
.lb-box{background:#fff;border-radius:10px;padding:16px;width:260px;display:flex;flex-direction:column;align-items:center;gap:10px;}
.lb-img{width:160px;height:160px;border-radius:8px;background:#f5f5f5;border:1px solid #e8e8e8;display:flex;align-items:center;justify-content:center;}
.lb-ref{font-size:14px;font-weight:500;}
.lb-specs{font-size:12px;color:#35823F;font-weight:500;text-align: center;}
.lb-desc{font-size:12px;color:#666;text-align:center;line-height:1.4;}
.lb-close{font-size:12px;color:#666;cursor:pointer;border:1px solid #ccc;border-radius:3px;padding:3px 12px;background:none;}
.lb-close:hover{border-color:#35823F;color:#35823F;}

/* project_infos */
#project_infos{font-size:12px;font-weight:400;line-height:1.4;width:100%;padding:8px 20px;background:#fff;border-top:3px solid #35823F;display:flex;gap:0;align-items:flex-start;}
.pi-col{flex:1;padding:0 14px 0 0;}
.pi-col:last-child{padding-right:0;flex:0.6;text-align:right;}
.pi-col+.pi-col{border-left:0.5px solid #e8e8e8;padding-left:14px;}
.pi-header{font-size:10px;font-weight:500;text-transform:uppercase;letter-spacing:.07em;color:#35823F;margin-bottom:5px;}
.pi-row{display:flex;justify-content:space-between;align-items:baseline;gap:4px;margin-bottom:3px;}
.pi-label{font-size:12px;color:#888;white-space:nowrap;flex-shrink:0;}
.pi-val{font-size:12px;font-weight:500;color:#3c3c3c;text-align:right;}
.pi-tag{display:inline-block;font-size:9px;padding:0 4px;border-radius:8px;background:#f0f7f1;color:#35823F;margin-left:2px;border:0.5px solid #9BC391;}
.pi-piece{display:flex;justify-content:space-between;align-items:baseline;gap:4px;margin-bottom:2px;}
.pi-piece-label{font-size:12px;color:#3c3c3c;}
.pi-piece.none .pi-piece-label{color:#bbb;font-style:italic;}
.pi-total{font-size:20px;font-weight:500;color:#35823F;line-height:1;}
.pi-total-sub{font-size:10px;color:#888;margin-top:1px;}
.pi-badge-delai{display:inline-flex;align-items:center;gap:3px;font-size:10px;padding:1px 6px;border-radius:8px;background:#f0f7f1;border:0.5px solid #9BC391;color:#35823F;font-weight:500;}
#project_infos i {font-size: 12px;}

/*outdated*/
.outdated {text-decoration: line-through;}
