/* Homepage-specific styles */

/* Hero */
.dsg-hero{background:linear-gradient(180deg,#fff 0%,var(--dsg-beige) 100%);overflow:hidden;position:relative;padding:4rem 0 3rem}
.dsg-hero:before{content:'';position:absolute;inset:0;background-image:linear-gradient(var(--dsg-grid) 1px,transparent 1px),linear-gradient(90deg,var(--dsg-grid) 1px,transparent 1px);background-size:32px 32px;pointer-events:none;opacity:.7;mask-image:linear-gradient(180deg,rgba(0,0,0,.8) 0%,rgba(0,0,0,0) 100%)}
.dsg-hero__inner{display:grid;grid-template-columns:1.05fr .95fr;gap:3rem;align-items:center;position:relative}
.dsg-hero__eyebrow{display:inline-block;background:rgba(31,35,38,.06);color:var(--dsg-graphite);padding:.4rem .8rem;border-radius:999px;font-size:.78rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;margin:0 0 1rem}
.dsg-hero__headline{font-size:clamp(2rem,4vw,3.2rem);font-weight:900;letter-spacing:-.02em;line-height:1.05;color:var(--dsg-graphite);margin:0 0 1rem}
.dsg-hero__sub{font-size:1.1rem;color:#3b4145;max-width:60ch;margin-bottom:1.5rem}
.dsg-hero__cta{display:flex;gap:.6rem;flex-wrap:wrap;margin-bottom:1rem}
.dsg-hero__badge{display:inline-flex;align-items:center;gap:.4rem;color:var(--dsg-orange-deep);font-weight:700;font-size:.92rem;background:rgba(255,122,24,.1);padding:.45rem .8rem;border-radius:999px}
.dsg-hero__visual{position:relative;min-height:380px}
.dsg-hero__card{position:absolute;background:#fff;border-radius:var(--dsg-radius-lg);box-shadow:var(--dsg-shadow-lg);overflow:hidden;border:1px solid var(--dsg-border)}
.dsg-hero__card--main{top:0;right:0;width:78%;aspect-ratio:5/3}
.dsg-hero__card--alt{bottom:0;left:0;width:54%;aspect-ratio:5/3}
.dsg-hero__card--mini{bottom:30%;right:-1rem;width:62%;padding:1rem 1.1rem;display:flex;flex-direction:column;background:var(--dsg-graphite);color:#fff;border-color:#000}
.dsg-hero__card--mini strong{font-size:.95rem}
.dsg-hero__card--mini small{color:#9aa1a6;font-size:.78rem}
.dsg-hero__safety{display:flex;flex-direction:column;gap:.15rem}
.dsg-hero__card img{width:100%;height:100%;object-fit:cover}
.dsg-hero__tag{position:absolute;bottom:.6rem;left:.6rem;background:#fff;color:var(--dsg-graphite);padding:.25rem .6rem;border-radius:999px;font-size:.72rem;font-weight:700;letter-spacing:.04em;text-transform:uppercase}
@media (max-width:880px){
  .dsg-hero__inner{grid-template-columns:1fr;gap:2rem}
  .dsg-hero__visual{min-height:300px}
}

/* Quickstart */
.dsg-quickstart__grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:.75rem}
.dsg-qs-card{display:flex;flex-direction:column;align-items:flex-start;gap:.5rem;background:#fff;border:1px solid var(--dsg-border);border-radius:var(--dsg-radius);padding:1rem;text-align:left;transition:transform .15s ease,border-color .15s ease,box-shadow .15s ease;cursor:pointer}
.dsg-qs-card:hover{transform:translateY(-2px);border-color:var(--dsg-orange);box-shadow:0 6px 16px rgba(255,122,24,.18)}
.dsg-qs-card.is-active{border-color:var(--dsg-orange);background:linear-gradient(180deg,#fff,#fff7f0);box-shadow:0 8px 22px rgba(255,122,24,.22)}
.dsg-qs-card.is-active .dsg-qs-card__icon{background:var(--dsg-orange);color:#fff}
.dsg-qs-card__icon{width:38px;height:38px;border-radius:10px;background:var(--dsg-graphite);color:var(--dsg-orange);display:inline-flex;align-items:center;justify-content:center}
.dsg-qs-card__label{font-weight:700;font-size:.95rem;line-height:1.2}
.dsg-qs-card__hint{font-size:.74rem;color:var(--dsg-steel);text-transform:uppercase;letter-spacing:.06em;font-weight:700}
.dsg-quickstart__reset{margin-top:1rem;text-align:center}

/* Categories */
.dsg-categories .dsg-product__title{font-size:1.1rem}

/* Compare table */
.dsg-compare__drawer-help{display:inline-flex;align-items:center;gap:.4rem;color:var(--dsg-orange-deep);font-weight:700;font-size:.88rem;background:rgba(255,122,24,.08);padding:.4rem .7rem;border-radius:999px;margin-top:.6rem}
.dsg-compare-table-wrap{overflow-x:auto;border:1px solid var(--dsg-border);border-radius:var(--dsg-radius-lg);background:#fff}
.dsg-compare-table{width:100%;border-collapse:collapse;min-width:680px}
.dsg-compare-table th,.dsg-compare-table td{padding:.95rem 1rem;text-align:left;vertical-align:top;border-bottom:1px solid var(--dsg-border)}
.dsg-compare-table thead th{background:var(--dsg-graphite);color:#fff;border-bottom:0;font-size:.9rem}
.dsg-compare-table thead th:first-child{background:transparent}
.dsg-compare-table tbody th{font-weight:700;color:var(--dsg-graphite);background:#fafaf7;width:140px}
.dsg-compare-table__h{display:block;font-weight:800}

/* Accessories */
.dsg-acc-card{display:flex;flex-direction:column;background:#fff;border:1px solid var(--dsg-border);border-radius:var(--dsg-radius);overflow:hidden;transition:transform .15s ease,box-shadow .15s ease;color:var(--dsg-graphite)}
.dsg-acc-card:hover{transform:translateY(-2px);box-shadow:var(--dsg-shadow);color:var(--dsg-graphite)}
.dsg-acc-card__img{display:block;background:var(--dsg-graphite);aspect-ratio:1/1}
.dsg-acc-card__img img{width:100%;height:100%;object-fit:cover}
.dsg-acc-card__body{padding:.7rem .8rem;display:flex;flex-direction:column;gap:.2rem}
.dsg-acc-card__body strong{font-size:.95rem}
.dsg-acc-card__body small{color:var(--dsg-orange-deep);font-weight:700;font-size:.78rem}

/* Education */
.dsg-edu-card{display:flex;flex-direction:column;gap:.5rem;background:#fff;border:1px solid var(--dsg-border);border-radius:var(--dsg-radius);padding:1.1rem 1.1rem 1.2rem;transition:transform .15s ease,box-shadow .15s ease;color:var(--dsg-graphite)}
.dsg-edu-card:hover{transform:translateY(-2px);box-shadow:var(--dsg-shadow);color:var(--dsg-graphite)}
.dsg-edu-card__icon{width:36px;height:36px;border-radius:10px;background:var(--dsg-beige);color:var(--dsg-oak);display:inline-flex;align-items:center;justify-content:center}
.dsg-edu-card small{color:var(--dsg-orange-deep);font-weight:700}

/* Trust */
.dsg-trust-card{background:#fff;border:1px solid var(--dsg-border);border-radius:var(--dsg-radius);padding:1.1rem;display:flex;flex-direction:column;gap:.5rem}
.dsg-trust-card__icon{width:36px;height:36px;border-radius:10px;background:var(--dsg-orange);color:#fff;display:inline-flex;align-items:center;justify-content:center}
.dsg-trust__links{margin-top:1rem;color:var(--dsg-steel);font-size:.92rem}
.dsg-trust__links a{color:var(--dsg-graphite);font-weight:700}
.dsg-trust__links a:hover{color:var(--dsg-orange-deep)}

/* Newsletter */
.dsg-newsletter{background:var(--dsg-graphite);color:#fff;border-radius:var(--dsg-radius-lg);margin:0 1.25rem;padding:0}
.dsg-newsletter .dsg-container{padding:2.5rem 1.25rem}
.dsg-newsletter__inner{display:grid;grid-template-columns:1.2fr 1fr;gap:1.5rem;align-items:center}
.dsg-newsletter h2{color:#fff}
.dsg-newsletter p{color:#cfd3d6;margin:0}
.dsg-newsletter__form{display:flex;gap:.5rem;flex-wrap:wrap}
.dsg-newsletter__form input{flex:1;min-width:240px;padding:.85rem 1rem;border-radius:999px;border:0;background:#fff;color:var(--dsg-graphite);font-size:1rem}
.dsg-newsletter__privacy{flex-basis:100%;color:#9aa1a6;font-size:.78rem;margin-top:.4rem}
.dsg-newsletter__privacy a{color:#fff;text-decoration:underline}
@media (max-width:720px){.dsg-newsletter__inner{grid-template-columns:1fr}}

/* 404 */
.dsg-404 .dsg-404__product{margin-bottom:2rem}
.dsg-404__head{margin:2rem 0 1.5rem}
.dsg-404__sub{color:var(--dsg-steel);font-size:1.05rem}
.dsg-404__grid{display:grid;grid-template-columns:1fr 1fr;gap:2rem;margin-top:1.5rem}
@media (max-width:720px){.dsg-404__grid{grid-template-columns:1fr}}

/* Horizontal product card — image on the left so the CTA stays above the fold.
   Use higher-specificity selectors so the base .dsg-product__media aspect-ratio
   rule from main.css cannot win the cascade. */
.dsg-product.dsg-product--horizontal{display:grid;grid-template-columns:minmax(0,320px) 1fr;align-items:stretch;gap:0}
.dsg-product.dsg-product--horizontal .dsg-product__media{aspect-ratio:auto;height:100%;min-height:0;max-height:280px;overflow:hidden}
.dsg-product.dsg-product--horizontal .dsg-product__media--capped{max-height:280px;overflow:hidden}
.dsg-product.dsg-product--horizontal .dsg-product__media img,
.dsg-product.dsg-product--horizontal .dsg-product__media--capped img{display:block;width:100%;height:100%;max-height:280px;object-fit:cover;object-position:center}
@media (max-width:768px){
  .dsg-product.dsg-product--horizontal{grid-template-columns:1fr}
  .dsg-product.dsg-product--horizontal .dsg-product__media,
  .dsg-product.dsg-product--horizontal .dsg-product__media--capped{max-height:180px}
  .dsg-product.dsg-product--horizontal .dsg-product__media img,
  .dsg-product.dsg-product--horizontal .dsg-product__media--capped img{max-height:180px}
}

/* Posts archive */
.dsg-post{background:#fff;border:1px solid var(--dsg-border);border-radius:var(--dsg-radius);overflow:hidden}
.dsg-post__media img{aspect-ratio:3/2;object-fit:cover;width:100%}
.dsg-post__title{font-size:1.1rem;font-weight:800;padding:.8rem 1rem 0}
.dsg-post__excerpt{padding:.4rem 1rem 1rem;color:var(--dsg-steel)}
