/* ==========================================================================
   DigitMak v2 — Section Styles (Institutional / Light)
   ========================================================================== */

/* ============ HERO ============ */
.dm-hero{position:relative;padding-top:calc(var(--dm-header-h) + clamp(2rem,4vw,4rem));padding-bottom:clamp(3.5rem,6vw,5.5rem);overflow:hidden;
  background:
    radial-gradient(90% 70% at 90% 0%, rgba(209,21,37,.05) 0%, transparent 50%),
    radial-gradient(70% 60% at 0% 100%, rgba(199,154,46,.05) 0%, transparent 55%),
    linear-gradient(180deg,#FBFCFD 0%,#F5F7FA 100%);}
.dm-hero::before{content:"";position:absolute;inset:0;z-index:0;pointer-events:none;
  background-image:linear-gradient(var(--dm-line) 1px,transparent 1px),linear-gradient(90deg,var(--dm-line) 1px,transparent 1px);
  background-size:56px 56px;opacity:.5;
  -webkit-mask-image:linear-gradient(180deg,#000 0%,transparent 75%);
  mask-image:linear-gradient(180deg,#000 0%,transparent 75%);}
.dm-hero .dm-container{position:relative;z-index:1}
.dm-hero__inner{display:grid;grid-template-columns:1.1fr .9fr;gap:clamp(2rem,5vw,4.5rem);align-items:center;position:relative;z-index:2}
.dm-hero__content{max-width:36rem}
.dm-hero__title{font-size:var(--dm-fs-hero);color:var(--dm-ink);margin-bottom:1.5rem;font-weight:500;letter-spacing:-.02em}
.dm-hero__title .accent{color:var(--dm-red);font-style:italic}
.dm-hero__lead{font-size:var(--dm-fs-lead);color:var(--dm-slate);line-height:1.65;margin-bottom:2rem;max-width:44ch}
.dm-hero__actions{display:flex;gap:1rem;flex-wrap:wrap;margin-bottom:2.75rem}
.dm-hero__stats{display:flex;gap:2.5rem;padding-top:1.75rem;border-top:1px solid var(--dm-line)}
.dm-hero__stat-num{font-family:var(--dm-font-display);font-size:2rem;font-weight:500;color:var(--dm-ink);line-height:1}
.dm-hero__stat-num .unit{color:var(--dm-red)}
.dm-hero__stat-label{font-family:var(--dm-font-mono);font-size:.72rem;letter-spacing:.08em;text-transform:uppercase;color:var(--dm-slate-40);margin-top:.5rem}

/* hero visual — quiet structured panel */
.dm-hero__visual{position:relative;aspect-ratio:1/1;max-width:480px;margin-left:auto;width:100%}
.dm-hero__panel{position:absolute;inset:0;border:1px solid var(--dm-line);border-radius:var(--dm-radius-lg);background:linear-gradient(160deg,#fff 0%,var(--dm-surface) 100%);overflow:hidden}
.dm-hero__panel-grid{position:absolute;inset:0;background-image:linear-gradient(var(--dm-line) 1px,transparent 1px),linear-gradient(90deg,var(--dm-line) 1px,transparent 1px);background-size:44px 44px;opacity:.5;mask-image:radial-gradient(circle at 50% 45%,#000 40%,transparent 80%)}
.dm-hero__nodes path{stroke:var(--dm-line-strong);stroke-width:1.25;fill:none}
.dm-hero__nodes circle{fill:var(--dm-red)}
.dm-hero__nodes .n-gold{fill:var(--dm-gold)}
.dm-hero__chip{position:absolute;display:flex;align-items:center;gap:.7rem;background:#fff;border:1px solid var(--dm-line);border-radius:var(--dm-radius);padding:.75rem .95rem;box-shadow:var(--dm-shadow-md)}
.dm-hero__chip-icon{width:34px;height:34px;border-radius:8px;display:grid;place-items:center;background:var(--dm-red-soft);color:var(--dm-red);flex-shrink:0}
.dm-hero__chip-icon svg{width:18px;height:18px}
.dm-hero__chip-icon--gold{background:var(--dm-gold-soft);color:var(--dm-gold)}
.dm-hero__chip-txt strong{display:block;font-family:var(--dm-font-display);font-size:.98rem;color:var(--dm-ink);line-height:1.1}
.dm-hero__chip-txt span{font-size:.78rem;color:var(--dm-slate)}
.dm-hero__chip--1{top:9%;left:-6%;animation:dm-float 7s ease-in-out infinite}
.dm-hero__chip--2{top:44%;right:-8%;animation:dm-float 7s ease-in-out infinite .8s}
.dm-hero__chip--3{bottom:9%;left:6%;animation:dm-float 7s ease-in-out infinite 1.6s}
@keyframes dm-float{0%,100%{transform:translateY(0)}50%{transform:translateY(-9px)}}
@media (prefers-reduced-motion:reduce){.dm-hero__chip{animation:none!important}}

/* ============ INTRO ============ */
.dm-intro__grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(2rem,5vw,4.5rem);align-items:center}
.dm-intro__body{color:var(--dm-slate);line-height:1.75}
.dm-intro__body p{margin-bottom:1.1rem}
.dm-intro__visual{position:relative;aspect-ratio:4/3;border-radius:var(--dm-radius-lg);overflow:hidden;border:1px solid var(--dm-line)}
.dm-intro__badge{position:absolute;left:1.5rem;bottom:1.5rem;right:1.5rem;display:flex;gap:.9rem;align-items:center;background:rgba(255,255,255,.96);backdrop-filter:blur(6px);border:1px solid var(--dm-line);border-radius:var(--dm-radius);padding:1rem 1.15rem;box-shadow:var(--dm-shadow-sm)}
.dm-intro__badge svg{width:26px;height:26px;color:var(--dm-gold);flex-shrink:0}
.dm-intro__badge strong{display:block;font-family:var(--dm-font-display);color:var(--dm-ink);font-size:1.02rem}
.dm-intro__badge span{font-size:.85rem;color:var(--dm-slate)}

/* ============ SERVICES ============ */
.dm-services__grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1.5rem}
.dm-service{position:relative;background:#fff;border:1px solid var(--dm-line);border-radius:var(--dm-radius-lg);padding:2rem 1.9rem;transition:border-color .3s var(--dm-ease),box-shadow .3s var(--dm-ease),transform .3s var(--dm-ease)}
.dm-service:hover{border-color:var(--dm-line-strong);box-shadow:var(--dm-shadow-md);transform:translateY(-3px)}
.dm-service__num{font-family:var(--dm-font-mono);font-size:.75rem;letter-spacing:.1em;color:var(--dm-slate-40);text-transform:uppercase}
.dm-service__icon{width:52px;height:52px;border-radius:12px;display:grid;place-items:center;background:var(--dm-surface);border:1px solid var(--dm-line);color:var(--dm-red);margin:1rem 0 1.25rem}
.dm-service__icon svg{width:26px;height:26px}
.dm-service__title{font-size:var(--dm-fs-h3);margin-bottom:.65rem;color:var(--dm-ink)}
.dm-service__desc{font-size:.98rem;color:var(--dm-slate);line-height:1.65;margin-bottom:1.25rem}
.dm-service__list{list-style:none;margin:0 0 1.5rem;padding:0;display:flex;flex-direction:column;gap:.6rem}
.dm-service__list li{display:flex;gap:.65rem;align-items:flex-start;font-size:.92rem;color:var(--dm-ink-80)}
.dm-service__list svg{width:16px;height:16px;color:var(--dm-red);flex-shrink:0;margin-top:.28em}
.dm-service__link{display:inline-flex;align-items:center;gap:.5rem;font-size:.92rem;font-weight:600;color:var(--dm-red)}
.dm-service__link svg{width:16px;height:16px;transition:transform .25s}
.dm-service__link:hover svg{transform:translateX(3px)}

/* ============ PORTALS ============ */
.dm-portals{display:grid;grid-template-columns:1fr 1fr;gap:1.5rem}
.dm-portal{position:relative;display:flex;flex-direction:column;padding:2.5rem;border-radius:var(--dm-radius-lg);border:1px solid var(--dm-line);background:#fff;overflow:hidden;transition:box-shadow .35s var(--dm-ease),transform .35s var(--dm-ease),border-color .35s}
.dm-portal:hover{box-shadow:var(--dm-shadow-lg);transform:translateY(-4px);border-color:var(--dm-line-strong)}
.dm-portal__tag{align-self:flex-start;font-family:var(--dm-font-mono);font-size:.7rem;letter-spacing:.1em;text-transform:uppercase;color:var(--dm-slate);border:1px solid var(--dm-line);border-radius:100px;padding:.3rem .75rem;margin-bottom:1.75rem}
.dm-portal__icon-lg{width:56px;height:56px;border-radius:14px;display:grid;place-items:center;margin-bottom:1.25rem}
.dm-portal__icon-lg svg{width:28px;height:28px}
.dm-portal--oss .dm-portal__icon-lg{background:var(--dm-red-soft);color:var(--dm-red)}
.dm-portal--lms .dm-portal__icon-lg{background:var(--dm-gold-soft);color:var(--dm-gold)}
.dm-portal__title{font-size:1.5rem;color:var(--dm-ink);margin-bottom:.75rem}
.dm-portal__desc{font-size:.98rem;color:var(--dm-slate);line-height:1.65;margin-bottom:2rem;flex:1}
.dm-portal__link{display:inline-flex;align-items:center;gap:.5rem;font-weight:600;font-size:.95rem;color:var(--dm-red)}
.dm-portal__link svg{width:17px;height:17px;transition:transform .25s}
.dm-portal:hover .dm-portal__link svg{transform:translate(3px,-3px)}

/* ============ STATS BAND ============ */
.dm-statsband__grid{display:grid;grid-template-columns:repeat(4,1fr);gap:2rem}
.dm-stat{text-align:left;position:relative;padding-left:1.5rem}
.dm-stat::before{content:"";position:absolute;left:0;top:.1em;bottom:.4em;width:2px;background:var(--dm-red);border-radius:2px}
.dm-stat__num{font-family:var(--dm-font-display);font-size:clamp(2.4rem,4vw,3.2rem);font-weight:500;color:#fff;line-height:1}
.dm-stat__num .unit{color:var(--dm-red);font-style:italic}
.dm-stat__label{font-family:var(--dm-font-mono);font-size:.78rem;letter-spacing:.06em;text-transform:uppercase;color:rgba(255,255,255,.6);margin-top:.75rem}

/* ============ PROCESS / JOURNEY (ghost numeral) ============ */
.dm-journey__grid{display:grid;grid-template-columns:repeat(4,1fr);gap:2.25rem}
.dm-journey__step{position:relative;padding-top:3.5rem}
.dm-journey__num{position:absolute;top:-1.5rem;left:-.5rem;font-family:var(--dm-font-display);font-size:5rem;font-weight:500;color:var(--dm-surface-2);line-height:1;z-index:0;pointer-events:none;letter-spacing:-.02em}
.dm-journey__step:first-child .dm-journey__num{color:var(--dm-red-soft)}
.dm-journey__body{position:relative;z-index:1}
.dm-journey__title{font-family:var(--dm-font-display);font-size:1.2rem;color:var(--dm-ink);margin-bottom:.5rem;line-height:1.25}
.dm-journey__desc{font-size:.92rem;color:var(--dm-slate);line-height:1.62}

/* ============ PARTNERS ============ */
.dm-partners__grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1.25rem}
.dm-partner{display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;gap:.5rem;padding:1.75rem 1.25rem;background:#fff;border:1px solid var(--dm-line);border-radius:var(--dm-radius);min-height:150px;transition:border-color .25s,box-shadow .25s,transform .25s;color:inherit}
.dm-partner:hover{border-color:var(--dm-line-strong);box-shadow:var(--dm-shadow-sm);transform:translateY(-2px)}
.dm-partner__logo{max-height:52px;width:auto;object-fit:contain;filter:grayscale(1);opacity:.7;transition:filter .3s,opacity .3s}
.dm-partner:hover .dm-partner__logo{filter:grayscale(0);opacity:1}
.dm-partner__name{font-family:var(--dm-font-display);font-size:1rem;color:var(--dm-ink);line-height:1.2}
.dm-partner__role{font-family:var(--dm-font-mono);font-size:.68rem;letter-spacing:.08em;text-transform:uppercase;color:var(--dm-slate-40)}
.dm-partner__role--lead{color:var(--dm-red)}

/* ============ CARDS (news/events) ============ */
.dm-cards__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.75rem}
.dm-card{display:flex;flex-direction:column;background:#fff;border:1px solid var(--dm-line);border-radius:var(--dm-radius-lg);overflow:hidden;transition:border-color .3s,box-shadow .3s,transform .3s}
.dm-card:hover{border-color:var(--dm-line-strong);box-shadow:var(--dm-shadow-md);transform:translateY(-3px)}
.dm-card__media{position:relative;aspect-ratio:16/10;background:var(--dm-surface);overflow:hidden;display:block}
.dm-card__media img{width:100%;height:100%;object-fit:cover;transition:transform .5s var(--dm-ease)}
.dm-card:hover .dm-card__media img{transform:scale(1.04)}
.dm-card__tag{position:absolute;top:1rem;left:1rem;font-family:var(--dm-font-mono);font-size:.68rem;letter-spacing:.06em;text-transform:uppercase;background:#fff;color:var(--dm-red);padding:.35rem .65rem;border-radius:100px;border:1px solid var(--dm-line)}
.dm-card__tag--event{color:var(--dm-gold)}
.dm-card__body{padding:1.5rem;display:flex;flex-direction:column;flex:1}
.dm-card__date{font-family:var(--dm-font-mono);font-size:.75rem;color:var(--dm-slate-40);margin-bottom:.6rem}
.dm-card__title{font-size:1.2rem;margin-bottom:.6rem;line-height:1.3}
.dm-card__title a{color:var(--dm-ink)}
.dm-card__title a:hover{color:var(--dm-red)}
.dm-card__excerpt{font-size:.92rem;color:var(--dm-slate);line-height:1.6;margin-bottom:1.25rem;flex:1}
.dm-card__more{display:inline-flex;align-items:center;gap:.45rem;font-size:.9rem;font-weight:600;color:var(--dm-red)}
.dm-card__more svg{width:15px;height:15px;transition:transform .25s}
.dm-card__more:hover svg{transform:translateX(3px)}

/* ============ QUOTE ============ */
.dm-quote{max-width:60rem;margin-inline:auto;text-align:center}
.dm-quote__mark{font-family:var(--dm-font-display);font-size:4rem;line-height:.5;color:var(--dm-red);opacity:.35;margin-bottom:1rem}
.dm-quote__text{font-family:var(--dm-font-display);font-size:clamp(1.4rem,2.4vw,2rem);line-height:1.4;color:var(--dm-ink);font-weight:400;margin-bottom:2rem;font-style:italic}
.dm-section--ink .dm-quote__text{color:#fff}
.dm-quote__author{display:flex;align-items:center;justify-content:center;gap:.9rem}
.dm-quote__avatar{width:48px;height:48px;border-radius:50%;object-fit:cover}
.dm-quote__name{font-family:var(--dm-font-display);color:var(--dm-ink);font-size:1rem}
.dm-section--ink .dm-quote__name{color:#fff}
.dm-quote__role{font-size:.85rem;color:var(--dm-slate)}

/* ============ FAQ ============ */
.dm-faq{max-width:52rem;margin-inline:auto}
.dm-faq__item{border-bottom:1px solid var(--dm-line)}
.dm-faq__q{width:100%;display:flex;align-items:center;justify-content:space-between;gap:1rem;padding:1.4rem 0;background:none;border:none;cursor:pointer;text-align:left;font-family:var(--dm-font-display);font-size:1.15rem;color:var(--dm-ink)}
.dm-faq__icon{flex-shrink:0;width:24px;height:24px;display:grid;place-items:center;color:var(--dm-red);transition:transform .3s var(--dm-ease)}
.dm-faq__icon svg{width:18px;height:18px}
.dm-faq__q[aria-expanded="true"] .dm-faq__icon{transform:rotate(45deg)}
.dm-faq__a{overflow:hidden;max-height:0;transition:max-height .4s var(--dm-ease)}
.dm-faq__a-inner{padding:0 0 1.4rem;color:var(--dm-slate);line-height:1.7;font-size:.98rem;max-width:64ch}

/* ============ CTA ============ */
.dm-cta{position:relative;background:var(--dm-ink-panel);border-radius:var(--dm-radius-lg);padding:clamp(2.5rem,5vw,4.5rem);text-align:center;overflow:hidden}
.dm-cta__deco{position:absolute;inset:0;width:100%;height:100%;opacity:.5}
.dm-cta__deco path{stroke:rgba(255,255,255,.14)}
.dm-cta__deco circle{fill:var(--dm-red);opacity:.6}
.dm-cta>*{position:relative;z-index:1}
.dm-cta__title{font-size:var(--dm-fs-h2);color:#fff;margin-bottom:1rem;max-width:20ch;margin-inline:auto}
.dm-cta__desc{font-size:var(--dm-fs-lead);color:rgba(255,255,255,.72);max-width:52ch;margin:0 auto 2.25rem}
.dm-cta__actions{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap}

/* ============ CONTACT ============ */
.dm-contact__grid{display:grid;grid-template-columns:.9fr 1.1fr;gap:2.5rem;align-items:stretch}
.dm-contact__info{position:relative;background:var(--dm-surface);border:1px solid var(--dm-line);border-radius:var(--dm-radius-lg);padding:2.5rem;overflow:hidden}
.dm-contact__info-title{font-size:var(--dm-fs-h3);color:var(--dm-ink);margin-bottom:.75rem}
.dm-contact__info-desc{font-size:.98rem;color:var(--dm-slate);line-height:1.65;margin-bottom:2rem}
.dm-contact__item{display:flex;gap:.9rem;align-items:flex-start;padding:1rem 0;border-top:1px solid var(--dm-line)}
.dm-contact__item-icon{width:38px;height:38px;border-radius:9px;display:grid;place-items:center;background:#fff;border:1px solid var(--dm-line);color:var(--dm-red);flex-shrink:0}
.dm-contact__item-icon svg{width:18px;height:18px}
.dm-contact__item strong{display:block;font-family:var(--dm-font-body);font-weight:600;color:var(--dm-ink);font-size:.9rem}
.dm-contact__item span{font-size:.92rem;color:var(--dm-slate)}
.dm-contact__form{background:#fff;border:1px solid var(--dm-line);border-radius:var(--dm-radius-lg);padding:2.5rem}

/* ============ RESPONSIVE ============ */
@media (max-width:960px){
  .dm-hero__inner{grid-template-columns:1fr;gap:3rem}
  .dm-hero__content{order:1}
  .dm-hero__visual{max-width:420px;margin-inline:auto;order:2}
  .dm-intro__grid{grid-template-columns:1fr;gap:2.5rem}
  .dm-services__grid,.dm-portals{grid-template-columns:1fr}
  .dm-statsband__grid{grid-template-columns:repeat(2,1fr);gap:2rem 1.5rem}
  .dm-journey__grid{grid-template-columns:1fr 1fr;gap:3rem 2.25rem}
  .dm-partners__grid{grid-template-columns:repeat(3,1fr)}
  .dm-cards__grid{grid-template-columns:1fr 1fr}
  .dm-contact__grid{grid-template-columns:1fr}
}
@media (max-width:600px){
  .dm-hero__stats{flex-wrap:wrap;gap:1.5rem}
  .dm-statsband__grid{grid-template-columns:1fr 1fr}
  .dm-partners__grid{grid-template-columns:1fr 1fr}
  .dm-cards__grid{grid-template-columns:1fr}
  .dm-journey__grid{grid-template-columns:1fr;gap:2.75rem}
  .dm-hero__chip--1{left:0}.dm-hero__chip--2{right:0}.dm-hero__chip--3{left:0}
}

/* ============ SINGLE POST / EVENT ============ */
.dm-post__head{padding-top:calc(var(--dm-header-h) + clamp(2.5rem,5vw,4rem));padding-bottom:clamp(1.75rem,3vw,2.5rem);text-align:center}
.dm-post__head .dm-container{max-width:820px}
.dm-post__back{display:inline-flex;align-items:center;gap:.5rem;font-family:var(--dm-font-mono);font-size:.78rem;letter-spacing:.04em;text-transform:uppercase;color:var(--dm-slate);margin-bottom:2rem}
.dm-post__back svg{width:15px;height:15px;transform:rotate(180deg);transition:transform .25s var(--dm-ease)}
.dm-post__back:hover{color:var(--dm-red)}
.dm-post__back:hover svg{transform:rotate(180deg) translateX(3px)}
.dm-post__title{font-size:var(--dm-fs-h1);color:var(--dm-ink);margin-bottom:1.5rem;line-height:1.1}
.dm-post__meta{display:flex;justify-content:center;gap:1.75rem;flex-wrap:wrap;padding-top:1.5rem;border-top:1px solid var(--dm-line)}
.dm-post__meta-item{display:inline-flex;align-items:center;gap:.5rem;font-family:var(--dm-font-mono);font-size:.82rem;color:var(--dm-slate)}
.dm-post__meta-item svg{width:16px;height:16px;color:var(--dm-red)}
.dm-post__cover{margin-bottom:clamp(2.5rem,5vw,3.5rem)}
.dm-post__cover .dm-container{max-width:1000px}
.dm-post__cover-frame{border-radius:var(--dm-radius-lg);overflow:hidden;aspect-ratio:16/9;border:1px solid var(--dm-line)}
.dm-post__cover-frame img{width:100%;height:100%;object-fit:cover}
.dm-post__body{padding-bottom:clamp(3rem,6vw,5rem)}
.dm-post__body .dm-container{max-width:720px}
.dm-post__cta{margin-top:2.5rem}
.dm-post__tags{display:flex;flex-wrap:wrap;gap:.6rem;margin-top:2.5rem;padding-top:2rem;border-top:1px solid var(--dm-line)}
.dm-post__tag{font-family:var(--dm-font-mono);font-size:.8rem;color:var(--dm-slate);border:1px solid var(--dm-line);border-radius:100px;padding:.35rem .85rem;transition:all .2s}
.dm-post__tag:hover{border-color:var(--dm-red);color:var(--dm-red)}

/* ============ ARCHIVE / INDEX HEADER ============ */
.dm-archive__head{padding-top:calc(var(--dm-header-h) + clamp(2.5rem,5vw,4rem));padding-bottom:clamp(2rem,4vw,3rem);border-bottom:1px solid var(--dm-line);margin-bottom:clamp(2.5rem,5vw,3.5rem)}
.dm-archive__title{font-size:var(--dm-fs-hero);color:var(--dm-ink);line-height:1.05;letter-spacing:-.02em;margin-bottom:1rem}
.dm-archive__count{font-family:var(--dm-font-mono);font-size:.82rem;letter-spacing:.06em;text-transform:uppercase;color:var(--dm-slate-40)}
